前端架構: 腳手架包管理工具之lerna的全流程開發教程

Lerna


1 )文檔

  • Lerna 文檔
    • https://www.npmjs.com/package/lerna
    • https://lerna.js.org [請直達這個鏈接]
  • 使用 Lerna 幫助我們做包管理,并不復雜,中間常用的命令并不是很多
  • 這里是命令直達:https://lerna.js.org/docs/api-reference/commands

2 )使用

  • 現在我們開始使用 Lerna, 首先創建目錄 lerna
  • 安裝并查看 lerna 版本 $ npx lerna -v 這里沒有安裝,會自動安裝 lerna
  • 目前lerna的版本是8.1.2
  • 在 lerna 這個目錄下執行 $ npx lerna init
  • 這時候,項目初始化完成了,就會多處一個 lerna.json 這個是lerna配置文件
  • 現在基于 lerna 創建 a包 $ npx lerna create a 一路回車
  • 現在出現了 packages/a 包,里面有一系列配置
  • 同workspace使用一致,在使用a的時候,把a加到分組中, 修改 a/package.json中的name
  • "name":"@somegroup/lerna-a", 并且把 a/lib/a.js 修改成 a/lib/index.js
  • 同步 a/package.json 中 "main": "lib/index.js", 同時修改成ESM的形式 "type":"module"
  • 修改 a/lib/index.js 的代碼
    'use strict';export default function() {return 'Hello from a';
    }
    
  • 這樣,a包就調試好了, 可以在 lerna/package.json 中看到
    "workspaces": ["packages/*"
    ],
    
    • 這里的worksapces 使用了通配符*的方式
  • 不同于 npm的workspace添加依賴的方式,lerna提供的方式是:$ npx lerna add -h
  • 注意,這里 The “add” command was removed by default in v7, and is no longer maintained.
  • 所以,新提供的方式是: https://lerna.js.org/docs/legacy-package-management#replacing-your-usage-of-lerna-add
  • 現在給a包添加chalk依賴: $ npm i chalk -w @somegroup/lerna-a 注意這里a包的name變化了,所以安裝方式也要如此
  • 這里,a包就緒之后,就可以著手創建b包了,在創建的時候,可以看下一些輔助參數 $ npx lerna create -h
  • 可以看到常用的有
    --access        When using a scope, set publishConfig.access value                        [可選值: "public", "restricted"] [默認值: public]
    --bin           Package has an executable. Customize with --bin <executableName>          [默認值: <name>]
    --es-module     Initialize a transpiled ES Module                                         [布爾]
    
  • 這樣,在創建b包的時候,就可以這樣 $ npx lerna create b --access public 回車,注意name配置為:@somegroup/lerna-b
  • 創建 cli 包的時候,就可以這樣 $ npx lerna create cli --access public --bin --es-module 回車,注意name配置為:@somegroup/lerna-cli
  • 對于b包
    • 修改 b/lib/b.js 為 b/lib/index.js, 同時修改 b/package.json 中的 "main": "lib/index.js""type": "module"
      • 注意,這里和 cli包的區別在于生成b包的時候 --es-module 沒有添加,所以要手動添加這個 "type": "module"
    • 修改 b/lib/index.js 的內容
      'use strict';export default function () {return 'Hello from b';
      }
      
  • 對于 cli 包
    • 修改 cli/package.json 中的 bin屬性為:"bin": { "lerna-cli": "bin/cli.js" }, main屬性 "main":"src/cli.js"

    • 修改 cli/bin/cli.js 中

      #!/usr/bin/env node'use strict';import cli from '../src/cli.js';cli().parse(process.argv.slice(2));
      
    • 修改 src/cli.js

      import factory from 'yargs/yargs';export default function cli(cwd) {const parser = factory(null, cwd);parser.alias('h', 'help');parser.alias('v', 'version');parser.usage("$0","TODO: description",yargs => {yargs.options({// TODO: options});});return parser;
      }
      
  • 回到最外層 lerna 目錄,嘗試連接下:npx lerna link,發現報錯
    • 報錯內容為:The “link” command was removed by default in v7, and is no longer maintained.
    • 解決方案:https://lerna.js.org/docs/legacy-package-management#replacing-your-usage-of-lerna-bootstraplerna-link
  • 使用 $ npm i -ws 這樣,三個包都會在 lerna/node_modules/@somegroup 組中會被同步,這樣可以替代之前lerna的link命令
    • npm i -ws 是更新所有 workspaces 中的依賴
  • 現在在 lerna/package.json 中的最外層加上一個 cli 的 scripts
    {"scripts": {"cli": "lerna-cli"}
    }
    
  • 執行 $ npm run cli
  • 這樣,cli 包就可以直接在 lerna 目錄下執行了, 驗證
    • $ npm run cli -v 得到 10.2.3 這里得到的是 npm 的版本
  • 至此,基于 lerna 的腳手架的功能框架完成,目前并沒有提供什么實質的功能
  • 現在,要在 cli 包中使用a包和b包,在 lerna 目錄下,執行 $ npm i @somegroup/lerna-a @somegroup/lerna-b -w packages/cli
  • 在 lerna/packages/cli/bin/cli.js 中使用
    #!/usr/bin/env node'use strict';import cli from '../src/cli.js';
    import a from '@somegroup/lerna-a';
    import b from '@somegroup/lerna-b';console.log(a());
    console.log(b());cli().parse(process.argv.slice(2));
    
  • 執行 cli,$ npm run cli 可以看到,打印出了a, b包中的方法提供的字符串

3 )測試

  • 使用 lerna 添加測試腳本 $ npx lerna run test 它會把 packages 目錄中所有 test 腳本全部執行
  • 如果要單獨測試某個包,比如a包,修改 packages/a/__tests__ 目錄下的 a.test.js
    'use strict';import a from '../lib/index.js';
    import assert from 'assert';const { strict } = assert;assert.strictEqual(a(), 'Hello from a');
    console.info('a tests passed');
    
  • 這時候,在 packages/a 下執行 $ npm run test 測試通過
  • 同樣,packages/* 下的所有包都可以這樣修改后,執行測試用例

4 )發布

  • 發布前的再次檢查
    • 每個包的版本都要注意同步檢查,發布的時候,不要有錯誤
    • 發布的配置檢查,在 package.json 中 "publishConfig": { "access": "public" } 都要有
    • 提交代碼到遠程倉庫后(必須)
  • 所有事項準備完成,就可以執行發布的流程了,執行 $ npx lerna publish
    • 這里有步驟,可以選擇下一個版本,填入必要信息或選項
    • 選擇之后,本地packages下包的每個版本都會幫忙升級,非常方便

5 )驗證

  • 發布完成后,可以本機全局安裝我們的 @somegroup/lerna-cli 工具了
  • $ npm i -g @somegroup/lerna-cli@latest 或者指定版本號
  • 再執行 $ lerna-cli 就可以運行我們的腳手架了
  • 這樣基于lerna開發的腳手架就已經完成了

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/710949.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/710949.shtml
英文地址,請注明出處:http://en.pswp.cn/news/710949.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

掌匯云 | FBIF個性化票務系統,展會活動數據好沉淀

“把票全賣光&#xff01;賣到一票難求&#xff0c;現場座無虛席。” 賣票人和買票人可能永遠不在一個頻道上。 2022年辦活動&#xff0c;就是一個字&#xff0c;搏&#xff01;和“黑天鵝”趕時間&#xff0c;能不能辦不由主辦方說了算。這種情況在2023年得到了改善&#xff…

【字典樹】【KMP】【C++算法】3045統計前后綴下標對 II

作者推薦 動態規劃的時間復雜度優化 本文涉及知識點 字符串 字典樹 KMP 前后綴 LeetCode:3045統計前后綴下標對 II 給你一個下標從 0 開始的字符串數組 words 。 定義一個 布爾 函數 isPrefixAndSuffix &#xff0c;它接受兩個字符串參數 str1 和 str2 &#xff1a; 當 st…

C++——內存管理(new和delete)詳解

目錄 C/C內存管理 案例&#xff1a;變量在內存中到底會在哪&#xff1f; New和delete Operator new和operator delete函數 New和delete的原理 對內置類型 對自定義類型 定位new New/delete和malloc/free的區別 C/C內存管理 C/C內存管理分布圖&#xff1a;&#xff08;從…

項目案例:圖像分類技術在直播電商中的應用與實踐

一、引言 在數字化浪潮的推動下&#xff0c;電商行業迎來了一場革命性的變革。直播電商&#xff0c;作為一種新興的購物模式&#xff0c;正以其獨特的互動性和娛樂性&#xff0c;重塑著消費者的購物習慣。通過實時的直播展示&#xff0c;商品的細節得以清晰呈現&#xff0c;而互…

matlab:涉及復雜函數圖像的交點求解

matlab&#xff1a;涉及復雜函數圖像的交點求解 在MATLAB中求解兩個圖像的交點是一個常見的需求。本文將通過一個示例&#xff0c;展示如何求解兩個圖像的交點&#xff0c;并提供相應的MATLAB代碼。 畫出圖像 首先&#xff0c;我們需要繪制兩個圖像&#xff0c;以便直觀地看…

【JavaEE】_HttpServletResponse類

目錄 1. 核心方法 2. 關于setStatus(400)與sendError 2.1 setStatus(400) 2.2 sendError 3. setHeader方法 4. 構造重定向響應 4.1 使用setHeader和setStatus實現重定向 4.2 使用sendRedirect實現重定向 本專欄已有文章介紹HttpServlet和HttpServletRequest類&#…

仿真科普|CAE技術賦能無人機 低空經濟蓄勢起飛

喝一杯無人機送來的現磨熱咖啡&#xff1b;在擁堵的早高峰打個“空中的士”上班&#xff1b;乘坐水陸兩棲飛機來一場“陸海空”立體式觀光……曾經只出現在科幻片里的5D城市魔幻場景&#xff0c;正逐漸走進現實。而推動上述場景實現的&#xff0c;就是近年來越來越熱的“低空經…

前端開發——ElementUI組件的使用

文章目錄 1. Tabs標簽頁2. 單選框 el-radio3. 復選框 el-checkbox4. 下拉框 el-select5. 表格 el-table6. 對話框 el-dialog7. 文字提示 el-tooltip8. 抽屜 el-drawer 1. Tabs標簽頁 <template><el-tabs v-model"activeName" tab-click"handleClick&q…

python學生成績管理系統(期末課程作業)

功能介紹 平臺采用B/S結構&#xff0c;后端采用主流的Python語言進行開發&#xff0c;前端采用主流的Vue.js進行開發。本學期的期末作業。開發了1周 功能包括&#xff1a;成績管理、學生管理、課程管理、班級管理、用戶管理、日志管理、系統信息模塊。 源碼地址 https://gi…

c語言求簡單交錯序列前N項和

本題要求編寫程序,計算序列 1 - 1/4 1/7 - 1/10 ... 的前N項之和。 輸入格式: 輸入在一行中給出一個正整數N。 輸出格式: 在一行中按照“sum S”的格式輸出部分和的值S&#xff0c;精確到小數點后三位。題目保證計算結果不超過雙精度范圍。 輸入樣例: 10輸出樣例: su…

如何實現WordPress后臺顯示文章、分類目錄、標簽等的ID?

我們平時在使用WordPress的過程中&#xff0c;偶爾需要用到文章的ID&#xff0c;或分類目錄ID&#xff0c;或標簽ID&#xff0c;或媒體庫ID&#xff0c;或評論ID&#xff0c;或用戶ID等&#xff0c;但是WordPress后臺默認是不顯示它們的ID的。 今天boke112百科就跟大家分享如何…

聚觀早報 | 愛奇藝2023年Q4財報;蘋果將加大AI投入

聚觀早報每日整理最值得關注的行業重點事件&#xff0c;幫助大家及時了解最新行業動態&#xff0c;每日讀報&#xff0c;就讀聚觀365資訊簡報。 整理丨Cutie 3月1日消息 愛奇藝2023年Q4財報 蘋果將加大AI投入 意大利正與多家車企談判 多家企業與百度達成合作 比亞迪宋PL…

Cesium 視頻貼圖

一、創作靈感 a、在cesium中視頻或者圖像在矩形或者圓形中顯示 b、在不使用entity模式下,使用Primitive進行視頻或者圖像渲染 c、在使用Primitive的前提下,需要進行視頻或者圖像貼地 d、不貼地,請跳轉到我的另外一份日志紋理貼圖 二、創建步驟 1、創建圓形或者矩形 創建圓…

SpringBoot集成接口重試Retry

SpringBoot集成接口重試Retry 前言 在實際的應用中&#xff0c;我們經常需要調用第三方API來獲取數據或執行某些操作。然而&#xff0c;由于網絡不穩定、第三方服務異常等原因&#xff0c;API調用可能會失敗。為了提高系統的穩定性和可靠性&#xff0c;我們通常會考慮實現重試…

SDR架構 (一)為什么基帶有I和Q路?

我之前做過自己的RTL-SDR。一直有一個疑惑。為啥rtl2832u芯片有一對差分I路&#xff0c;還有一對差分Q路。差分很好理解是為了抗干擾&#xff0c;但為啥要I和Q呢&#xff1f;并且我也知道不少人在自己修改的時候&#xff0c;保留I路對接在r820t2&#xff08;跟原版一樣&#xf…

整數與IP地址間的轉換(牛客網算法/Javascript Node)

描述 原理&#xff1a;ip地址的每段可以看成是一個0-255的整數&#xff0c;把每段拆分成一個二進制形式組合起來&#xff0c;然后把這個二進制數轉變成 一個長整數。 舉例&#xff1a;一個ip地址為10.0.3.193 每段數字 相對應的二進制數 10 00001010 0 00000000 3 00000011 193…

開放簽電子簽章企業版上線【移動端功能(v1.5版本)】

春節序曲奏響創新華章&#xff0c;緊鑼密鼓的工作節奏下&#xff0c;開放簽支持移動端簽署啦&#xff01; 在這個萬家燈火的春節之際&#xff0c;開放簽團隊憑借高效的團隊協作&#xff0c;在節日的熱烈氛圍中成功推出了全新版本&#xff08;企業版1.5版&#xff09;&#xff…

逆變器專題(12)-弱電網

相應仿真原件請移步資源下載 通常情況下&#xff0c;理想電網都為強電網&#xff0c;但隨著光伏并網系統的大力發展&#xff0c;分布式光伏也越發鼎盛&#xff0c;越來越多的電力電子設備接入大電網、并且考慮能源利用問題&#xff0c;大部分光伏電站都建在戈壁沙漠等地區&…

多行業萬能預約門店小程序源碼系統 支持多門店預約小程序 帶完整的安裝代碼包以及搭建教程

隨著消費者對于服務體驗要求的不斷提升&#xff0c;門店預約系統成為了許多行業提升服務質量、提高運營效率的重要工具。然而&#xff0c;市面上的預約系統往往功能單一&#xff0c;無法滿足多行業、多場景的個性化需求。下面&#xff0c;小編集合了多年的行業經驗和技術積累&a…

巖土工程中的振弦采集儀技術發展與前景展望

巖土工程中的振弦采集儀技術發展與前景展望 河北穩控科技振弦采集儀是一種常用的巖土工程監測儀器&#xff0c;用于測量土壤或巖石的振動特性。隨著巖土工程領域的發展和技術的進步&#xff0c;振弦采集儀技術也得到了不斷的發展和改進。以下是對振弦采集儀技術發展與前景的展…