package和package-lock区别;dependencies和devDependencies区别

package和package-lock

package.json: 主要用来定义项目中需要依赖的包

package-lock.json: 在 npm install时候生成一份文件,用以记录当前状态下实际安装的各个npm package的具体来源和版本号。

'^' : 放在版本号之前,表示向后兼容依赖,说白了就是在大版本号不变的情况下,下载最新版的包

项目中引入的包版本号之前经常会加^号,每次在执行npm install之后,下载的包都会发生变化,为了系统的稳定性考虑,每次执行完npm install之后会对应生成package-lock文件,该文件记录了上一次安装的具体的版本号,相当于是提供了一个参考,在出现版本兼容性问题的时候,就可以参考这个文件来修改版本号即可。

dependencies和devDependencies

一个node package有两种依赖,一种是dependencies一种是devDependencies,其中前者依赖的项该是正常运行该包时所需要的依赖项,而后者则是开发的时候需要的依赖项,像一些进行单元测试之类的包。

如果你将包下载下来在包的根目录里运行

npm install 
//默认会安装两种依赖,如果你只是单纯的使用这个包而不需要进行一些改动测试之类的,可以使用

npm install --production
//只安装dependencies而不安装devDependencies。

如果你是通过以下命令进行安装

npm install packagename
//那么只会安装dependencies,如果想要安装devDependencies,需要输入

npm install packagename --dev  

devDependencies : 用于本地环境开发时候。
dependencies : 用户发布环境

devDependencies是只会在开发环境下依赖的模块,生产环境不会被打入包内。通过NODE_ENV=developement或NODE_ENV=production指定开发还是生产环境。
而dependencies依赖的包不仅开发环境能使用,生产环境也能使用。其实这句话是重点,按照这个观念很容易决定安装模块时是使用--save还是--save-dev。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文是一篇英文blog翻译,原文"A Beginener's Guide to npm - the Node Pa...
    chr1s_gong阅读 1,142评论 0 1
  • npm是什么 NPM的全称是Node Package Manager,是随同NodeJS一起安装的包管理和分发工具...
    build1024阅读 7,988评论 0 9
  • 常见问题 1.npm 的package.json中的~和^ 会匹配最近的小版本依赖包,比如1.2.3会匹配所有1....
    RayLeo阅读 2,348评论 0 0
  • 最近上了一堂在线课程,崔璀主讲的《经营自己——人人都需要的管理术》(关于崔璀,她是蓝狮子公司的前COO,如果没听过...
    罗大满阅读 244评论 0 0
  • 你可以走的慢。但不要停下来,期待与你一起成长! 寒假离校前我去了心理咨询室,约老师做了一次体验式沙盘,在沙盘上,我...
    慢慢的心雨阅读 447评论 0 0