1、表面区别
npm install
在安装npm
包时,有两种命令参数可以把它们的信息写入package.json
文件,一个是npm install --save
另一个是npm install --save-dev
,它们表面上的区别是--save
会把依赖包名称添加到package.json
文件dependencies
键下,--save-dev
则添加到 package.json
文件devDependencies
键下。
2、package.json文件
{
"dependencies": {
"vue": "^2.2.1"
},
"devDependencies": {
"babel-core": "^6.0.0",
"babel-loader": "^6.0.0",
"babel-preset-latest": "^6.0.0",
"cross-env": "^3.0.0",
"css-loader": "^0.25.0",
"file-loader": "^0.9.0",
"vue-loader": "^11.1.4",
"vue-template-compiler": "^2.2.1",
"webpack": "^2.2.0",
"webpack-dev-server": "^2.2.0"
}
}
3、本质区别
npm
自己的文档说dependencies
是运行时依赖,devDependencies
是开发时的依赖。即devDependencies
下列出的模块,是开发时使用,比如安装js
的压缩包gulp-uglify
时,采用的是npm install --save-dev gulp-uglify
命令安装,因为在发布后用不到它,而只是在开发才用到它。dependencies
下的模块,则是发布后还需要使用的依赖模块,譬如jQuery
库或者Vue
框架等,在开发完后肯定还要依赖它们,否则就运行不了。正常使用npm install
时,会下载dependencies
和devDependencies
中的模块,当使用npm install --production
或者注明NODE_ENV
变量值为production
时,只会下载dependencies
中的模块。