中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

發布一款npm包幫助理解npm的使用

發布時間:2020-10-24 23:20:56 來源:腳本之家 閱讀:188 作者:AndyLaw 欄目:web開發

npm 在前端工程化中扮演著不可或缺的角色,前端工程師每天通過npm安裝項目依賴,通過npm發布自己的包,更新包,通過npm 腳本運行開發環境,打包等。

平時專注于實現業務,一直沒有去了解一款包的發布流程,忙里偷閑,今天就體驗下編寫并發布一個package的過程,記錄下來分享給大家。

一個包誕生的過程無非是:編寫-測試-發布-迭代-測試-發布...,

初始化項目

mkdir math-tool_demo 新建文件夾

npm init初始化package.json文件,根據提示輸入項目信息:

  • package name項目名
  • version 版本
  • description 描述
  • entry point 入口文件
  • test command 測試命令
  • git repository git倉庫地址
  • keywords 關鍵字信息
  • author 作者
  • 協議等

發布一款npm包幫助理解npm的使用

npm init -y:添加 -y 標志,直接默認生成.

編寫包里的代碼

包含的功能:我們實現一個加減乘除的小工具。

新建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')
  }
}

測試

測試無非就是引入編寫的模塊,并運行測試用例,此處不再多說。

發布

npm login 登錄。輸入賬戶密碼郵箱,如果你沒有賬戶,先申請:鏈接。

 發布一款npm包幫助理解npm的使用

npm publish:發布編寫的包

失敗:命名重復或類似: 修改一下包名。

發布一款npm包幫助理解npm的使用

再次發布:npm publish:成功了!默認版本為1.0.0

發布一款npm包幫助理解npm的使用

如何迭代發布的包

包發布出去了,bug是無法避免的,當然作者也會考慮擴展功能,修復bug或功能迭代需要將代碼修改同步到遠程倉庫。

修改代碼

比如做出了下述的修改:

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 提供的命令修改版本號(比如當前為v1.0.0):

  • npm version patch-->1.0.1:屬于小修改,不更改功能使用
  • npm version minor-->1.1.0:可能添加了一些功能,不影響以前的使用。
  • npm version major-->2.0.0:可能改了API,輸入大范圍的修改。

詳細移步:關于npm語義版本

發布

npm publish

如何使用發布的包

  • 到npm倉庫搜索包名
  • 然后,輸入npm install packageName -S [-D ]分別作為依賴或開發依賴

下面以我們剛發布的包為例:

首次使用該包
npm install -S math-tool_demo 安裝剛剛發布的包

在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

正在使用,該包可能已經迭代更新

npm outdated檢查每個定義在項目package.json中包在遠程倉庫是否有新版本

發布一款npm包幫助理解npm的使用

發現有新版本,目前使用的是1.0.0,最新的是2.0.0。

npm update [packageName]更新包

發布一款npm包幫助理解npm的使用

敲完,發現沒反應,并沒有更新包。

查看package.json中包的依賴定義

發布一款npm包幫助理解npm的使用

有三種版本定義:

  • 直接寫準確的版本號:比如:1.0.0
  • 大版本不動,有功能更新則用新版本:^1.0.0
  • 更保守一點,只能小幅更新如bug修復等:~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中的版本號,并更新了。

為何弄成這樣?因為第一個數字意味著major改動,貿然的更新可能會帶來無法預計的后果

傳送門:npm-outdated,npm-update

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳谷县| 永州市| 固阳县| 汝城县| 蒙山县| 宁乡县| 托克托县| 辽阳县| 米易县| 腾冲县| 万安县| 高雄市| 怀集县| 页游| 永兴县| 霍林郭勒市| 女性| 西乌珠穆沁旗| 家居| 阿鲁科尔沁旗| 射阳县| 西畴县| 宜兰县| 健康| 台中市| 静海县| 吴桥县| 缙云县| 固镇县| 手机| 永登县| 佛教| 长汀县| 广平县| 永兴县| 任丘市| 辉县市| 东港市| 枝江市| 漾濞| 凤阳县|