大家好, 用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。
以前我们说到dependencies和devDependencies的时候,大家会想到啥?我想大家只会想到
dependencies
:生产环境需要的依赖devDependencies
:开发环境需要的依赖但是我们装依赖的时候真的会去考虑npm install -D
还是npm install -S
吗?
其实我们并不会去关心哪些是生产环境
所需依赖,哪些是开发环境
所需依赖,但是这也正常,因为其实在SPA项目
中,这两个东西并不需要区分!所以我们平时没有过多了解也正常!!!
我为什么说在SPA项目
中这两个东西没什么区别呢?我们接着往下看!
所谓SPA项目,其实指的就是单页面应用,比如说Vue、React项目这些
我们从开发环境
和生产环境
这两个时机来讨论
开发环境
中,我们开发项目时,我们肯定是两种包都需要安装的生产环境
中,我们是将开发环境
的代码,使用某些打包工具,例如Webpack,将整个项目代码打包成一些静态的文件,然后将这些静态文件部署到服务器上,也就是到达生产环境
所以大家也看到了,只有开发环境
时需要装包,生产环境
是不需要装包的,所以你把包放在dependencies和devDependencies中是没有区别的。
为什么这么说呢?因为其实无论你把包放在哪里都好,只要你代码中引用到了这个包,那么Webpack打包时就会把这个包打包进静态文件中。
比如我把vue
这个包放在devDependencies
开发依赖中,我Webpack打包时就不会打包这个vue
包吗?事实上是会的,因为Webpack打包是按照你依赖了啥,去打包的,并不会去看你这个包放在哪里!
所以,在开发SPA项目
时,dependencies和devDependencies并没啥区分意义。。
刚刚说完SPA项目
,它想要上生产环境
是需要使用打包工具打包成静态文件的,所以包放在哪里都无所谓,反正打包时候,只要依赖到的都会打进去。
但是Nodejs项目
却不一样,它上线的话,是不用打包的,是将整个完整项目代码扔到服务器上,然后运行,所以它是需要区分dependencies和devDependencies的。因为当它部署到服务器上之后,也就是生产环境
之后,它是需要再npm install
一次的。
我举个例子,我在开发环境
的时候,我需要做单元测试,我装了单元测试所需要的依赖包,那么这个包我是放在dependencies还是放在devDependencies呢?我们分情况讨论哈。
开发环境
下进行npm install
时是会安装的,而生产环境
下npm install
是不会安装的,这很合理,因为我肯定是生产环境测试无误
后再上生产环境
,所以我单元测试所需依赖包只需要在开发环境
安装即可,到了生产环境
我并不需要这个包开发环境、生产环境
下进行npm install
时都是会安装的,这并不合理啊,我生产环境
时并不需要用到这些单元测试的包啊!所以在Nodejs项目中
,dependencies还是放在devDependencies是有区分的意义的
我开发了一个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