你真的懂 npm 版本号以及其更新的策略吗

本文主要是说明 package.json 中 npm 版本规则以及 npm install 和 npm update 的区别,适合新手和老鸟复习。 

npm 中的版本号规则

版本的格式

    major.minor.patch

    主版本号.次版本号.修补版本号

版本匹配规则

version

    必须匹配某个版本

    如:1.1.2,表示必须依赖 1.1.2 版

>version

    必须大于某个版本

    如:>1.1.2,表示必须大于 1.1.2 版

>=version

    可大于或等于某个版本

    如:>=1.1.2,表示可以等于 1.1.2,也可以大于 1.1.2 版本

    必须小于某个版本

    如:<1.1.2,表示必须小于 1.1.2 版本

<=version

    可以小于或等于某个版本

    如:<=1.1.2,表示可以等于 1.1.2,也可以小于 1.1.2 版本

~version

    大概匹配某个版本

    如果 minor 版本号指定了,那么 minor 版本号不变,而 patch 版本号任意

    如果 minor 和 patch 版本号未指定,那么 minor 和 patch 版本号任意

    如:~1.1.2,表示 >= 1.1.2 < 1.2.0,可以是 1.1.2,1.1.3,1.1.4,.....,1.1.n

    如:~1.1,表示 >= 1.1.0 < 1.2.0,可以是同上

    如:~1,表示 >= 1.0.0 < 2.0.0,可以是 1.0.0,1.0.1,1.0.2,.....,1.0.n,1.1.n,1.2.n,.....,1.n.n

^version

    兼容某个版本

    版本号中最左边的非 0 数字的右侧可以任意

    如果缺少某个版本号,则这个版本号的位置可以任意

    如:^1.1.2 ,表示 >=1.1.2 <2.0.0,可以是 1.1.2,1.1.3,.....,1.1.n,1.2.n,.....,1.n.n

    如:^0.2.3 ,表示 >=0.2.3 <0.3.0,可以是 0.2.3,0.2.4,.....,0.2.n

    如:^0.0,表示 >=0.0.0 <0.1.0,可以是 0.0.0,0.0.1,.....,0.0.n

x 标识符

    x 的位置表示任意版本

    如:1.2.x,表示可以 1.2.0,1.2.1,.....,1.2.n

标识符

    任意版本,"" 也表示任意版本

    如:*,表示 >=0.0.0 的任意版本

version1 - version2

    大于等于 version1,小于等于 version2

    如:1.1.2 - 1.3.1,表示包括 1.1.2 和 1.3.1 以及他们件的任意版本

range1 || range2

    满足 range1 或者满足 range2,可以多个范围

    如:<1.0.0 || >=2.3.1 <2.4.5 || >=2.5.2 <3.0.0,表示满足这3个范围的版本都可以

install 和 update 区别

The difference between npm install and npm update handling of package versions specified in package.json

总结: 两者最大的区别是在对待已经安装过的模糊版本时候

    npm install会忽略模糊版本

    npm update会更新模糊版本至最新

另外: install and update 处理 devDependencies 方式也不同

    npm install 会安装/更新devDependencies,除非你指定 --production标志

    npm update 会忽略 devDependencies,除非你指定 --dev 标志

来自 https://stackoverflow.com/questions/12478679/npm-install-vs-update-whats-the-difference

你可能感兴趣的:(你真的懂 npm 版本号以及其更新的策略吗)