webpack配置package.json时devDependencies与dependencies?

发布于 2022-09-07 21:33:13 字数 1202 浏览 29 评论 0

最近在学习webpack4的过程中,针对以前从来没有注意过的细节进行深究,发现了一些不是很明白的问题,现在我的package.json配置文件里引用了webpack,webpack-cli,html-webpack-plugin,clean-webpack-plugin,这些都是工具,无需多言,我是打包进devDependencies里面的,然后我再开发index.js的时候,引入了jquery,我开始想,这个理论上是应该放在dependencies里面的,因为生产模式需要,但是如果我放在devDependencies里面会怎么样呢?以下是我不停的实验得出的结论(每一次实验,为确保准确,都彻底删除node_modules文件夹,重新一个一个安装):
1.放在devDependencies里,mode设置为development(开发模式),打包出的文件可以正常使用jquery;
2.放在devDependencies里,mode设置为production(生产模式),打包出的文件可以正常使用jquery;
3.放在dependencies里,mode设置为development(开发模式),打包出的文件可以正常使用jquery;
4.放在dependencies里,mode设置为production(生产模式),打包出的文件可以正常使用jquery;

{
  "name": "vuetest",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "build": "webpack --config webpack.prod.js",
    "start": "webpack-dev-server --open --config webpack.dev.js"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "clean-webpack-plugin": "^0.1.19",
    "html-webpack-plugin": "^3.2.0",
    "jquery": "^3.3.1",
    "webpack": "^4.16.5",
    "webpack-cli": "^3.1.0"
  }
}

what?
我开始怀疑人生了,我开始不明白dependencies和devDependencies到底是用来干嘛的了,因为我看不到一点点区别,我不明白它存在的意义是什么了,还有与之对应的生产模式和开发模式又是什么?求大神不吝赐教,万分感谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

哥,最终变帅啦 2022-09-14 21:33:13

实际上呢,webpack打包跟package.json配置文件根本没有半毛钱关系,他只与webpack自身有关,
dependencies和devDependencies只有在特定情况下才有用(比如在Node项目的生产环境上),
webpack打包是依赖于node_modules文件夹的,只要这个文件夹里有相应的模块,就可以打包,
至于平时为什么写--save和--save-dev是因为团队合作的原因,写进package.json里,才方便团队协作

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文