摘要:翻譯瘋狂的技術宅原文本文首發微信公眾號歡迎關注,每天都給你推送新鮮的前端技術文章本文描述了通過生成包的最小設置。是用于轉換的預設。有關這兩個屬性的更多信息設置多平臺包。表示使用上一節中的配置。結論以上是通過創建包最小庫的方法。
翻譯:瘋狂的技術宅
原文:http://2ality.com/2017/07/npm...
本文首發微信公眾號:jingchengyideng
歡迎關注,每天都給你推送新鮮的前端技術文章
本文描述了通過 Babel 生成 npm 包的最小設置。你可以在 GitHub 中看到案例 re-template-tag 的設置。
GitHub:https://github.com/rauschma/r...
1 核心結構有兩組文件:
目錄 esm/ 里有庫的(還轉換)實際源碼。
package.json 中的 module 屬性指向 esm/index.js
目錄 test/ 含有基于AVA的對 esm/ 中代碼的測試。
目錄 cjs/ 有 ESM 文件的已轉換版本,它們是 CommonJS 格式并支持在當前版本的 Node.js 環境下運行。
package.json 中的 main 屬性指向 cjs/index.js
此結構支持兩種用例:
Node.js 應用使用 cjs/ 中的文件。
Web應用(通過 webpack 等)使用 esm/ 中的文件。它們通過 babel-preset-env 將這些文件轉換為其目標平臺支持的功能集。 另一篇文章 中描述了如何執行這個操作。
到此我們僅部分解決了如何填充可能缺少的庫這個問題。接下來要徹底解決它
2 .gitignorecjs node_modules
cjs/ 沒有提交到 git。我們只是在 npm 發布包之前按需生成它。
3 .npmignorenode_modules
發布到 npm 時,我們需要包含 cjs/。這就是除了 .gitignore 之外我們還需要 .npmignore 的原因。
4 package.json package.json 的主要部分可以使用以下腳本:
"scripts": { "build": "babel esm --out-dir cjs", "prepublishOnly": "npm run build", "test": "ava" },
build 用于生成 cjs/中的文件。
prepublishOnly 能夠確保在我們發布到 npm 之前始終構建 cjs /。
test 通過 AVA 運行測試。
因此,我們有以下依賴項(僅在開發時):
"devDependencies": { "babel-cli": "^6.24.1", "ava": "^0.21.0", "babel-preset-env": "^1.5.1", "babel-register": "^6.24.1" },
單元測試需要ava。
babel-cli 提供命令 babel。
babel-register 讓 AVA 通過 Babel 執行測試。
babel-preset-env 是 Babel 用于轉換的預設。
"main": "./cjs/index.js", "module": "./esm/index.js",
main 是 CommonJS 格式的包入口點(包括在Node.js上運行的普通模塊)。
module是 ESM 格式的包入口點(包括webpack,取決于你如何設置它)。
有關這兩個屬性的更多信息:“設置多平臺 npm 包”。
配置 Babel對于Babel,我們用 babel-preset-env 典型的方式為當前運行的 Node.js 生成代碼。
"babel": { "presets": [ [ "env", { "targets": { "node": "current" } } ] ] },配置 AVA
對于 AVA,我們需要 babel-register,它通過 Babel 轉換所有測試和導入。 "babel": "inherit" 表示 AVA 使用上一節中的配置。
"ava": { "require": [ "babel-register" ], "babel": "inherit" }5 結論
以上是通過 Babel 創建 npm 包最小庫的方法。重要的一點是它允許包的客戶端使用 babel-preset-env(就像通過npm提供未轉換的源代碼 ”中所講的那樣)。所以它并沒有 100% 的正確使用 module ,但是有廣泛支持的優勢,并且沒有引入另一個 package.json 屬性。
6 擴展閱讀免費在線書籍: “Setting up ES6”
Delivering untranspiled source code via npm
babel-preset-env: a preset that configures Babel for you
歡迎繼續閱讀本專欄其它高贊文章:12個令人驚嘆的CSS實驗項目
世界頂級公司的前端面試都問些什么
CSS Flexbox 可視化手冊
過節很無聊?還是用 JavaScript 寫一個腦力小游戲吧!
從設計者的角度看 React
CSS粘性定位是怎樣工作的
一步步教你用HTML5 SVG實現動畫效果
程序員30歲前月薪達不到30K,該何去何從
第三方CSS安全嗎?
談談super(props) 的重要性
本文首發微信公眾號:jingchengyideng 歡迎掃描二維碼關注公眾號,每天都給你推送新鮮的前端技術文章文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/102383.html
摘要:文檔翻譯系列一安裝原文地址原文本系列是針對文檔進行的翻譯,因為自己在學習的時候,最開始通過看博客或者論壇等中文資料,有些內容是零零散散的接收,并沒有給自己帶來很好的效果,所以后來決定把文檔的原文從頭到尾看一遍。 React文檔翻譯系列(一)安裝 原文地址:原文 本系列是針對React文檔進行的翻譯,因為自己在學習react的時候,最開始通過看博客或者論壇等中文資料,有些內容是零零散散的...
摘要:手牽手搭建前端組件庫本文梳理如何搭建和構建前端組件庫了解幾個問題為何需要組件化大部分項目起源都是源于業務方的各種各樣的奇葩需求。作者是否私有,需要修改為才能發布到開源協議參考配置添加文件發布時,只有編譯后的目錄才需要被發布。 手牽手搭建前端組件庫 本文梳理如何搭建和構建前端組件庫. showImg(https://segmentfault.com/img/bVboZDt?w=1200&...
摘要:手牽手搭建前端組件庫本文梳理如何搭建和構建前端組件庫了解幾個問題為何需要組件化大部分項目起源都是源于業務方的各種各樣的奇葩需求。作者是否私有,需要修改為才能發布到開源協議參考配置添加文件發布時,只有編譯后的目錄才需要被發布。 手牽手搭建前端組件庫 本文梳理如何搭建和構建前端組件庫. showImg(https://segmentfault.com/img/bVboZDt?w=1200&...
摘要:也能幫你寫代碼了微軟和團隊一起推出擴展,預覽版可以在插件市場直接查找安裝。微軟宣布將采用內核這對于諸多的前端開發者而言,無疑是本年底最大的福音具體的計劃可以參考官網的博客,在不久的將來,基于的瀏覽器將要正式和我們見面啦。 訂閱 / 投稿:https://github.com/txd-team/monthly本期小編:?Hkmu (扶容)?/?x-cold (尹摯) 新聞快報 npm ...
閱讀 2829·2023-04-26 01:00
閱讀 757·2021-10-11 10:59
閱讀 2982·2019-08-30 11:18
閱讀 2680·2019-08-29 11:18
閱讀 1022·2019-08-28 18:28
閱讀 3018·2019-08-26 18:36
閱讀 2136·2019-08-23 18:16
閱讀 1070·2019-08-23 15:56