国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

開發更好用的 JavaScript 模塊

瀏覽:2日期:2023-11-11 16:17:39

開發更好用的 JavaScript 模塊

不少人都曾經在 npm 上發布過自己開發的 JavaScript 模塊,而在使用一些模塊的過程中,我經常產生“這個模塊很有用,但如果能 xxx 就更好了”的想法。所以,本文將站在模塊使用者的角度總結一下,如何能讓模塊變得更好用。

提供 ES6 模塊的入口

webpack 和 rollup 都支持對 ES6 模塊做一些靜態優化(例如 Tree Shaking 和Scope Hoisting),它們都會優先讀取 package.json 中的 module 字段作為 ES6 模塊的入口,若沒有 module 才會讀取 main 字段作為 CommonJS 模塊的入口。通常的做法是:使用 ES6 語法編寫源碼,然后用模塊打包工具結合語法轉換工具生成 CommonJS 模塊和 ES6 模塊,這樣就可以同時提供 main 和 module 字段了。

提供 TypeScript 的類型聲明文件

如果你的用戶使用了 TypeScript 但你的模塊沒有提供聲明文件,他們就不得不在項目中添加一段代碼避免 TypeScript 的編譯錯誤;另外,這樣做并不只是對使用 TypeScript 的用戶友好,因為大部分代碼編輯器(Webstorm、VS Code 等)都能識別 TypeScript 的類型聲明,它們可以據此提供更精準的代碼提示并在用戶傳入錯誤的參數個數或類型時給出提示。

最好的做法是使用 TypeScript 編寫你的模塊,編譯時會自動生成類型聲明。除此之外,你也可以參照 文檔 手動維護一份聲明文件。你可以在你的模塊根目錄下添加 index.d.ts 文件,或者在 package.json 中聲明 typings 字段提供聲明文件的位置。

讓模塊同時在 Node.js 與瀏覽器中運行

你可以通過檢測是否有名為 window 的全局變量(例如 !!typeof window )來判斷模塊當前是運行在 Node.js 還是瀏覽器中,然后使用不同的方式實現你的功能。

這種方法比較常見,但如果用戶使用了模塊打包工具,這樣做會導致 Node.js 與瀏覽器的實現方式都會被包含在最終的輸出文件中。針對這個問題,開源社區提出了在 package.json 中添加 browser 字段的 提議 ,目前 webpack 和 rollup 都已經支持這個字段了。

browser 字段有兩種使用方式:

給 browser 字段提供一個文件路徑作為在瀏覽器端使用時的模塊入口,但需要注意的是,打包工具會優先使用 browser 字段指定的文件路徑作為模塊入口,所以你的 module 字段會被忽略,這會導致打包工具不會優化你的代碼。詳細信息請參考 這個問題 。 如果你只想替換其中一些文件,你可以聲明一個對象。

舉個例子,假設你的模塊里有兩個文件: http.js 和 xhr.js ,第一個文件使用 Node.js 中的 http 模塊發起請求,另一個使用瀏覽器中的 XMLHTTPRequest 實現了同樣的功能。為了使用適當的文件,你的模塊代碼中應該始終 require(’./path/to/http.js’) ,并在 package.json 中聲明:

{ 'browser': { './path/to/http.js': './path/to/xhr.js' }}

這樣一來,當你的模塊在打包工具中使用時,打包工具只會將 xhr.js 的代碼包含在最終的輸出文件中。

使用各種服務武裝你的項目

大部分 JavaScript 項目都是開源的,而開源社區也提供了很多針對開源項目的免費服務,它們可以給你的項目提供更有力的幫助,這里列舉幾個比較常用的。

一個項目最常使用的服務就是持續集成了。持續集成服務能將測試、代碼風格檢測、打包等任務放在服務器上,并在你提交代碼時自動運行,常用的有 Travis CI 、 CircleCI 和 AppVeyor 。Travis CI 對開源項目免費,提供 Linux 與 OS X 運行環境;CircleCI 對開源與私有項目都免費,但每個月有 1500 分鐘的運行時間限制;AppVeyor 提供 Windows 運行環境,同樣對開源項目免費。

運行完測試之后,你還可以將測試覆蓋率上傳到 Coveralls 。這個服務能讓你在線瀏覽代碼的測試覆蓋情況。

如果你想讓你的模塊在各個版本的各種瀏覽器、平臺下得到充分的測試,你還可以使用 Sauce Labs 和 BrowserStack ,它們都是對開源項目免費的,但需要發郵件申請。

最后, Shields IO 提供了各種圖標,這些圖標能為你的項目提供很多額外信息,包括但不限于 npm 版本號、下載量、測試通過狀態、測試覆蓋率、文件大小、依賴是否過期等。

雖然以上的建議大多屬于錦上添花,但這會讓你的模塊對用戶更加友好,希望以上的建議能在你開發自己的模塊時給你一點幫助。

來自:https://zhuanlan.zhihu.com/p/31499310

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 久久久免费网站 | 亚洲欧美国产高清va在线播放 | 成人影视免费 | 久久久久欧美国产精品 | 一级做a爰性色毛片免费 | 黄视频在线免费看 | 国产三级免费观看 | 88av视频 | 久久久久免费精品视频 | 久久精品国产精品青草 | 亚洲精品tv久久久久 | 欧美三级不卡视频 | 一本色道久久综合亚洲精品 | 九九热视频精品在线观看 | 亚洲一区二区三区四区 | 久久福利影视 | 国产精品国产三级国产a | 亚洲成年男人的天堂网 | 久久久久久久性高清毛片 | 中文字幕乱码中文乱码51精品 | 亚洲精品久久精品h成人 | 亚洲第一中文字幕 | a级毛片在线观看 | 精品国产美女福利到在线不卡 | 国内精品七七久久影院 | 三级色网 | 在线观看国产区 | 日韩在线看片中文字幕不卡 | 精品xxxxxbbbb欧美中文 | 精品国产_亚洲人成在线高清 | 久久精品国产400部免费看 | 欧美大片一区 | 3至13呦女毛片 | 插美女网站 | 高清欧美不卡一区二区三区 | 中文字幕精品一区二区绿巨人 | 欧美成人久久 | 亚洲男人天堂网站 | 中文字幕毛片 | www.色中色 | 在线播放一区二区三区 |