时间:2021-05-25
webpack 的使用越来越广泛,但其中不乏很多鲜为人知的细节设置,甚至很多人会认为这是 webpack 的 bug。这次,我们就来聊一聊 webpack.optimize.CommonsChunkPlugin。
这个 plugin 我相信几乎90%的用 webpack 的都用了这个,但我同样相信几乎 90% 的用了这个 plugin 的人都没有正确的使用。
上面这个配置应该大家都不陌生吧?打包第三方 vendor。
其实这样写是有问题的。有什么问题呢?我们根据这个配置来操作一下。
首先,运行起来,我们会得到 vendor.js 的添加 hash 值过后的输出;
然后,修改index入口里面的任意文件,再次编译,得到 vendor.js 的添加 hash 值过后的输出;
最后,比较 vendor.js 两次编译的hash的值,你会惊讶的发现,为什么hash值改变了?我并没有修改vendor啊。
hash值改变了,那我们打包这个vendor也就没有意义了。
置于为什么会造成这个问题,我就不班门弄斧了,想要知道的人自己去研究一下webpack的底层。
在这里,我只是抛出一个解决方案:
没错,就是上面这个配置,只是简单的加了 'manifest' 。
再次做我们前面的测试,你会发现多了一个manifest.js,但是vendor的hash值不再变化了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近使用Webpack遇到了一个坑。我们构建前端项目的时候,往往希望第三方库(vendors)和自己写的代码可以分开打包,因为第三方库往往不需要经常打包更新。对
我们在用webpack打包是时候,常常想单独提取第三方库,把它作为稳定版本的文件,利用浏览缓存减少请求次数。常用的提取第三方库的方法有两种CommonsChun
平常我都是直接执行pipinstall安装的第三方库,很多教程也是这么介绍的,一直以来我都认为这是标准的、正确的安装Python第三方库的姿势。直到我最近看到P
webpack系列目录webpack系列二:webpack介绍&安装webpack系列三:webpack如何集成第三方js库webpack系列四:webpack
webpack系列目录webpack系列二:webpack介绍&安装webpack系列三:webpack如何集成第三方js库webpack系列四:webpack