dependencies 和 devDependencies 区别重新认识dependencies 和 devDependencies 区别重新认识


在之前的认识中只知道,vue打包到生产的文件要放到dependencies中,而本地开发的,类似webpack这种就放到devDependencies中,但没有细想一个问题,就是平常生产上都是用了vue build后的文件,那放到这个dependencies中其实也就没有存在还要额外依赖包的问题,于是继续往下打,发现原来区别如下:
问:

npm install –save-dev会保存到devDependencies中,npm install –save会保存到dependencies。
我在项目中用了vue-video插件,只存到了devDependencies中,打包以后插件也能正常运行。可dependencies中没有存,为什么插件不会报错?不是运行时依赖吗?

答:
这个dependencies做前端的时候不会有问题,因为最终代码都打包到发布文件里面去了。
写nodejs应用的时候很明显。nodejs没有打包这一说,需要的外部模块都是node_modules目录下的。

nodejs安装依赖有两种方法,一种是全部安装npm install,一种是安装生产环境的npm install –production

  1. dependencies 中的两种模式都会安装
  2. devDependencies 生产模式不会安装

所以生产环境用–production参数可以保证只下载运行应用必须的包。
比如我们开发时用到eslint,那这种需要放到devDependencies 中去,因为这种有没有这个包都不影响服务端代码的执行,只是约束开发时的代码风格。

 

如果 你的代码里 import了 这个包 那就是dependencies,没有就是devDependencies

 

 

比如可能存在单元测试、代码格式化等依赖项插件,这些依赖项对于这个项目本身而言并不是导入的模块,而是在开发时才需要用到,那么对于仅仅想运行一下项目、而非要开发项目的人来说,也必须 npm install 一遍。可你要知道 npm 早期版本可是以安装慢著称的(虽然从 npm 5.0 之后已经有很大改善了)。

所以搞出来了两个字段,如果只是想跑一遍项目,那么 npm install --production 就好了,这样只会下载安装 dependencies 里的依赖项。

转:https://www.jianshu.com/p/7a42e218ebd8

原创文章,作者:sunnyman218,如若转载,请注明出处:https://blog.ytso.com/244583.html

(0)
上一篇 2022年4月17日
下一篇 2022年4月17日

相关推荐

发表回复

登录后才能评论