dependencies和devDependencies有区分意义吗?

400次阅读  |  发布于2年以前

前言

大家好, 用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。

浑水摸鱼的说法?

以前我们说到dependenciesdevDependencies的时候,大家会想到啥?我想大家只会想到

但是我们装依赖的时候真的会去考虑npm install -D还是npm install -S吗?

其实我们并不会去关心哪些是生产环境所需依赖,哪些是开发环境所需依赖,但是这也正常,因为其实在SPA项目中,这两个东西并不需要区分!所以我们平时没有过多了解也正常!!!

我为什么说在SPA项目中这两个东西没什么区别呢?我们接着往下看!

所谓SPA项目,其实指的就是单页面应用,比如说Vue、React项目这些

SPA项目中 无区分意义!

我们从开发环境生产环境这两个时机来讨论

所以大家也看到了,只有开发环境时需要装包,生产环境是不需要装包的,所以你把包放在dependenciesdevDependencies中是没有区别的。

为什么这么说呢?因为其实无论你把包放在哪里都好,只要你代码中引用到了这个包,那么Webpack打包时就会把这个包打包进静态文件中。

比如我把vue这个包放在devDependencies开发依赖中,我Webpack打包时就不会打包这个vue包吗?事实上是会的,因为Webpack打包是按照你依赖了啥,去打包的,并不会去看你这个包放在哪里!

所以,在开发SPA项目时,dependenciesdevDependencies并没啥区分意义。。

Nodejs项目 有区分意义!

刚刚说完SPA项目,它想要上生产环境是需要使用打包工具打包成静态文件的,所以包放在哪里都无所谓,反正打包时候,只要依赖到的都会打进去。

但是Nodejs项目却不一样,它上线的话,是不用打包的,是将整个完整项目代码扔到服务器上,然后运行,所以它是需要区分dependenciesdevDependencies的。因为当它部署到服务器上之后,也就是生产环境之后,它是需要再npm install 一次的。

我举个例子,我在开发环境的时候,我需要做单元测试,我装了单元测试所需要的依赖包,那么这个包我是放在dependencies还是放在devDependencies呢?我们分情况讨论哈。

所以在Nodejs项目中dependencies还是放在devDependencies是有区分的意义的

开发NPM包 有区分意义!

我开发了一个NPM包,叫做npm-lsx,我在开发的过程中,我需要对我所开发的这个包进行单元测试,所以我安装了所需的依赖包npm-test,也就是依赖关系是npm-lsx -> npm-test

小明在做一个项目A,他项目中装了npm-lsx这个包,而大家都知道,你装一个包时,会连同你这个包所依赖的包都一起装,所以按理说npm-lsx、npm-test都会装,但是大家想想,项目A需要npm-test这个包吗?并不需要,这个包对于项目A来说没啥意义。

你可以理解为,项目A的 开发环境,其实就是 npm-lsx 的 生产环境。

所以我在开发npm-lsx的时候会把npm-test装在devDependencies中,这样,项目A就可以少装一些没意义的包,加快整体装包速度!

Copyright© 2013-2020

All Rights Reserved 京ICP备2023019179号-8