您当前的位置: 首页 >  前端

任磊abc

暂无认证

  • 0浏览

    0关注

    182博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

前端安装依赖时,npm --save-dev 与--save 的区别

任磊abc 发布时间:2020-05-23 17:11:12 ,浏览量:0

npm install 在安装 npm 包时,有两种命令参数可以把它们的信息写入 package.json 文件,一个是:

npm i  (依赖包)  --save-dev

or

npm i  (依赖包)   -D

    比如工程构建(开发时、“打包”时)依赖 ;例:xxx-cli , less-loader , babel-loader...

另一个是:

npm install (依赖包) --save

or


npm install (依赖包) -S

他们表面上的区别是--save 会把依赖包名称添加到 package.json 文件 dependencies 键下,--save-dev 则添加到 package.json 文件 devDependencies 键下,譬如:

{
 "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"
  }
}

不过这只是它们的表面区别。它们真正的区别是,npm自己的文档说dependencies是运行时依赖,devDependencies是开发时的依赖。即devDependencies 下列出的模块,是我们开发时用的,比如:

工程构建(开发时、“打包”时)依赖 ;例:xxx-cli , less-loader , uglifyjs-webpack-plugin,gulp-uglify,babel-loader...

我们安装 js的压缩包gulp-uglify 时,我们采用的是 “npm install –save-dev gulp-uglify ”命令安装,因为我们在发布后用不到它,而只是在我们开发才用到它。

dependencies 下的模块,则是我们发布后还需要依赖的模块,譬如像jQuery库或者Angular框架类似的,我们在开发完后后肯定还要依赖它们,否则就运行不了,比如:

  项目(运行时、发布到生产环境时)依赖;例:antd , element,react...

另外需要补充的是: 正常使用npm install时,会下载dependencies和devDependencies中的模块,当使用npm install –production或者注明NODE_ENV变量值为production时,只会下载dependencies中的模块。

关注
打赏
1656830895
查看更多评论
立即登录/注册

微信扫码登录

0.0371s