npm 语义化依赖管理
之前搞前端项目,经常遇到依赖的问题,这下学到了npm的依赖管理,以后应该能应对这些问题了
什么是语义化依赖管理
npm根据package.json中的dependencies字段来管理依赖,一般根据下面这种格式
"dependencies": {
"package-name": "version",
"express": "4.14.0"
}
npm中的version遵循语义化版本,就是如下的格式
"version": "MAJOR.MINOR.PATCH"
● 如果做了不兼容的API变动,就要增加主版本号(MAJOR)
● 当增加了向下兼容的新功能时,就要增加次版本号(MINOR)
● 当修复了向下兼容的bug时,应该增加修订号(PATCh)
维持最新的修订版本号
可以在依赖项的版本号前增加一个波浪号(~),可以让依赖更新的最新的修订版本,比如下面这个例子,就是允许更新到1.3.x版本
"package": "~1.3.8"
这种情况下,可以直接升级到任意的1.3.x版本,并且不需要更改原来的版本号
维持最新的次版本号
在依赖项的版本号前增加一个^,可以限制主版本号,更新最新的次版本号,下面这个例子就是允许更新到最新的1.x.x版本
"package": "^1.3.8"
这样就允许升级最新的次版本号并且不需要更改原来的版本号