美文网首页
dependencies 和 devDependencies 区

dependencies 和 devDependencies 区

作者: ChrinChen | 来源:发表于2020-11-17 10:29 被阅读0次

    最近使用webpack在写一个内部npm库插件,但遇到一个问题,在本地使用yarn和cnpm都可以正常下载,去到公司用的openshift自动发布系统上就怎么都没法把这个库down下来,于是各种排查,其中排查到下载的node_modules包里自己写的插件还会有一个node_modules包,怀疑是不是这里出了问题。

    20201117-01.jpeg

    在之前的认识中只知道,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 中去,因为这种有没有这个包都不影响服务端代码的执行,只是约束开发时的代码风格。

    相关文章

      网友评论

          本文标题:dependencies 和 devDependencies 区

          本文链接:https://www.haomeiwen.com/subject/ufcxiktx.html