發(fā)布一款npm包幫助理解npm的使用
npm 在前端工程化中扮演著不可或缺的角色,前端工程師每天通過npm安裝項目依賴,通過npm發(fā)布自己的包,更新包,通過npm 腳本運行開發(fā)環(huán)境,打包等。
平時專注于實現(xiàn)業(yè)務(wù),一直沒有去了解一款包的發(fā)布流程,忙里偷閑,今天就體驗下編寫并發(fā)布一個package的過程,記錄下來分享給大家。
一個包誕生的過程無非是:編寫-測試-發(fā)布-迭代-測試-發(fā)布...,
初始化項目
mkdir math-tool_demo
新建文件夾
npm init
初始化package.json文件,根據(jù)提示輸入項目信息:
- package name項目名
- version 版本
- description 描述
- entry point 入口文件
- test command 測試命令
- git repository git倉庫地址
- keywords 關(guān)鍵字信息
- author 作者
- 協(xié)議等
npm init -y
:添加 -y 標(biāo)志,直接默認(rèn)生成.
編寫包里的代碼
包含的功能:我們實現(xiàn)一個加減乘除的小工具。
新建index.js入口文件
module.exports = { add:add, minus:minus } function add(num1,num2) { if(typeof num1 === 'number' && typeof num2 === 'number'){ return num1 + num2; }else{ throw('arguments must be number') } } function minus(left,right){ if(typeof left === 'number' && typeof right === 'number'){ return left - right; }else{ throw('arguments must be number') } }
測試
測試無非就是引入編寫的模塊,并運行測試用例,此處不再多說。
發(fā)布
npm login 登錄。輸入賬戶密碼郵箱,如果你沒有賬戶,先申請:鏈接。
npm publish:發(fā)布編寫的包
失敗:命名重復(fù)或類似: 修改一下包名。
再次發(fā)布:npm publish:成功了!默認(rèn)版本為1.0.0
如何迭代發(fā)布的包
包發(fā)布出去了,bug是無法避免的,當(dāng)然作者也會考慮擴(kuò)展功能,修復(fù)bug或功能迭代需要將代碼修改同步到遠(yuǎn)程倉庫。
修改代碼
比如做出了下述的修改:
module.exports = { add:add, minus:minus } function add() { var left = arguments[0]; var right = arguments[1]; if(typeof left === 'number' && typeof right === 'number'){ return left + right; }else{ throw('arguments must be number') } } function minus(){ var left = arguments[0]; var right = arguments[1]; if(typeof left === 'number' && typeof right === 'number'){ return left - right; }else{ throw('arguments must be number') } }
修改版本號
我們可以直接改package.json里的version字段值.
不過最好還是使用npm 提供的命令修改版本號(比如當(dāng)前為v1.0.0):
- npm version patch-->1.0.1:屬于小修改,不更改功能使用
- npm version minor-->1.1.0:可能添加了一些功能,不影響以前的使用。
- npm version major-->2.0.0:可能改了API,輸入大范圍的修改。
詳細(xì)移步:關(guān)于npm語義版本
發(fā)布
npm publish
如何使用發(fā)布的包
- 到npm倉庫搜索包名
- 然后,輸入
npm install packageName -S [-D ]
分別作為依賴或開發(fā)依賴
下面以我們剛發(fā)布的包為例:
首次使用該包
npm install -S math-tool_demo
安裝剛剛發(fā)布的包
在index.js里引入并使用:
var math = require('math-tool_demo') var addRes = math.add(1,2); var minusRes = math.minus(1,2); console.log( addRes, minusRes, )//輸出:3,-1
正在使用,該包可能已經(jīng)迭代更新
npm outdated檢查每個定義在項目package.json中包在遠(yuǎn)程倉庫是否有新版本
發(fā)現(xiàn)有新版本,目前使用的是1.0.0,最新的是2.0.0。
npm update [packageName]
更新包
敲完,發(fā)現(xiàn)沒反應(yīng),并沒有更新包。
查看package.json中包的依賴定義
有三種版本定義:
- 直接寫準(zhǔn)確的版本號:比如:1.0.0
- 大版本不動,有功能更新則用新版本:^1.0.0
- 更保守一點,只能小幅更新如bug修復(fù)等:~1.0.0
^1.0.0意為>=1.0.0 < 1.2.0
~1.0.0意為>=1.0.0 < 1.1.0
因此更新到2.0.0的是不允許的,只能手動更改package.json中的版本號,并更新了。
為何弄成這樣?因為第一個數(shù)字意味著major改動,貿(mào)然的更新可能會帶來無法預(yù)計的后果
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
node.js入門教程之querystring模塊的使用方法
querystring模塊主要用來解析查詢字符串,下面這篇文章主要介紹了關(guān)于node.js中querystring模塊使用方法的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02利用node實現(xiàn)一個批量重命名文件的函數(shù)
這篇文章主要給大家介紹了關(guān)于利用node實現(xiàn)一個批量重命名文件的函數(shù)的相關(guān)資料,文中通過示例示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12簡單聊一聊Node.js參數(shù)max-old-space-size
簡單的說Node.js就是運行在服務(wù)端的JavaScript,下面這篇文章主要給大家介紹了關(guān)于Node.js參數(shù)max-old-space-size的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01Node 使用express-http-proxy 做api網(wǎng)關(guān)的實現(xiàn)
這篇文章主要介紹了Node 使用express-http-proxy 做api網(wǎng)關(guān)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10