迁移到webpack4:从webpack.optimize.CommonsChunkPlugin到config.optimization.splitChunk,以及有个搜出来的中文解决办法是错的

webpack4 Error: webpack.optimize.CommonsChunkPlugin has been removed, please use config.optimization.splitChunks instead

哦,原来是原来的插件不能用了,这个中文指南,标的是webpack4.7.0,结果这块都没更新啊。。。于是必应搜了一下,第一个出来的是这个

webpack4 Error: webpack.optimize.CommonsChunkPlugin has been removed, please use config.optimization.splitChunks instead 的解决方法

照着在webpack.config.js改了一下代码:

module.exports = {
plugins: [
- new webpack.optimize.CommonsChunkPlugin({
- name: ‘common‘ // 指定公共 bundle 的名称。
- })
],

+ optimization: {
+ splitChunks: {
+ name: ‘common‘
+ }
+ },

倒是不报错了,但仔细检查了一下,发现结果是:

//app.bundle.js 和 another.bundle.js 是共享 lodash模块的
Asset Size Chunks Chunk Names
another.bundle.js 70.1 KiB 0 [emitted] another
app.bundle.js 70.2 KiB 1 [emitted] app
another.bundle.js.map 668 KiB 0 [emitted] another
app.bundle.js.map 668 KiB 1 [emitted] app
index.html 253 bytes [emitted]

app.bundle.js 和 another.bundle.js 的大小都在70kib左右(1kib = 1,024Byte),相差无几且都大得不对劲,而且common.js根本没有生出来啊。。。这绝壁是有问题吧!!!

返回去老老实实看官方文档吧。。。

果然,是要这么配滴:

//optimization与entry/plugins同级
optimization: {
splitChunks: {
cacheGroups: {
commons: {
name: "commons",
chunks: "initial",
minChunks: 2
}
}
}
},

稍微解释一下含义

cacheGroups is an object where keys are the cache group names. All options from the ones listed above are possible: chunks, minSize, minChunks, maxAsyncRequests, maxInitialRequests, name. 可以自己设置一组一组的cache group来配对应的共享模块
commons里面的name就是生成的共享模块bundle的名字
With the chunks option the selected chunks can be configured.
chunks 有三个可选值,”initial”, “async” 和 “all”. 分别对应优化时只选择初始的chunks,所需要的chunks 还是所有chunks 。
minChunks 是split前,有共享模块的chunks的最小数目 ,默认值是1, 但我看示例里的代码在default里把它重写成2了,从常理上讲,minChunks = 2 应该是一个比较合理的选择吧。
出来的结果是:

Asset Size Chunks Chunk Names
commons.bundle.js 69.5 KiB 0 [emitted] commons
another.bundle.js 1.21 KiB 1 [emitted] another
app.bundle.js 1.26 KiB 2 [emitted] app
commons.bundle.js.map 664 KiB 0 [emitted] commons
another.bundle.js.map 6.9 KiB 1 [emitted] another
app.bundle.js.map 7.31 KiB 2 [emitted] app
index.html 317 bytes [emitted]
————————————————
版权声明:本文为CSDN博主「十方魔」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/github_36487770/article/details/80228147

原文地址:https://www.cnblogs.com/ygunoil/p/12420233.html

时间: 2024-10-14 09:34:14

迁移到webpack4:从webpack.optimize.CommonsChunkPlugin到config.optimization.splitChunk,以及有个搜出来的中文解决办法是错的的相关文章

Error: webpack.optimize.CommonsChunkPlugin has been removed, please use config.optimization.splitChunks instead.

按照webpack的指南,敲的demo中用到CommonsChunkPlugin这个插件,报如下错误: 指南上的用法: plugins: [ new HTMLWebpackPlugin({ title: 'Code Splitting' }), + new webpack.optimize.CommonsChunkPlugin({ + name: 'common' // 指定公共 bundle 的名称. + }) ], 解决方法: plugins: [ new HTMLWebpackPlugin

解决webpack打包速度慢的解决办法

技巧1 webpack在打包的时候第一次总是会做很长的准备工作,包括加载插件之类的.在刚接触webpack的时候总是webpack一下-测一下-改一下-再webpack一下,这种方式最后让很多人崩溃了觉得webpack一点都不好用.其实这是错误的使用方式. 正确的方式应直接执行webpack --watch 这样webpack会自动编译,第一回的时候确实很慢,但之后的自动编译就要快了好多,打包时间相差几倍. 技巧2 webpack配合的React,jQuery一些共有的库去使用,虽然没写几行代码

webpack无法使用相对路径解决办法

webpack无法使用相对路径: 当配置完webpack.config.js,path使用相对路径,如下: 但是,在cmd运行 webpack 时,报如下错误: 所以,解决办法: var path = require('path'); path: path.resolve(__dirname, './bin')

练习webpack遇到的一些问题以及解决办法,供自己以后参考

1.利用nodeJs安装webpack时报出以下错误提示: 这个错误我在网上搜了一下,说是npm文件配置问题,也就是权限不够 解决办法:npm config set registry http://registry.npmjs.org/  运行这行命令即可 2.自动监听文件变化 webpack中可以利用webpack-dev-server在localhost:8080端口启动一个express静态资源web服务器,并且默认以监听模式自动运行webpack,实时监听文件的变化: 首先安装:npm

不同类型的数据跨表空间迁移的解决办法

http://blog.csdn.net/passion_wang/article/details/6541369 Oracle10g数据跨表空间迁移 因某些开发人员由于对oracle数据库理解的不够深入,往往在建表的时候指定了当前用户非默认的表空间,这样就导致了在exp及imp等操作时候问题很多,因此需要将这些表及相关的数据迁移回当前用户的默认表空间里.Oracle10g数据数据库提供了一个Move命令可以把这样的数据对象进行跨表空间的迁移,也可以对含有BLOB.CLOB这样的二进制大字段的表

django数据库的表已迁移的不能重新迁移的解决办法

django.db.utils.InternalError: (1050, "Table 'tb_content' already exists") mysql数据库在迁移时数据库已存在. 解决办法:在数据库中的Django_migrations的表增加一行数据.Django_migrations是存储数据迁移记录的表.如出现上面的错误时,说明所生成的表中有重复的表,需要提示mysql数据库忽略该表的生成. 具体操作:在Django_migrations数据表中增加一行数据.在mysq

用vue-cli创建的项目没有webpack相关文件的解决办法

第一次使用vue-cli,版本是@vue/[email protected],按照官网上的教程: vue create my-project 发现生成的项目并没有webpack相关的文件, 也就是说没有集成webpack 解决办法是先: npm install -g @vue/cli-init 然后: vue init webpack my-project 这样生成的vue-cli项目就有webpack配置文件了 原文地址:https://www.cnblogs.com/xianxiaobo/p

当node升级后导致webpack打包出错,node-saas出问题的解决办法

报错信息如下: ERROR in ./node_modules/[email protected]@extract-text-webpack-plugin/dist/loader.js?{"omit":1,"remove":true}!D:/work/nl_web/node_modules/[email protected]@vue-style-loader!D:/work/nl_web/node_modules/[email protected]@css-load

Tomcat因项目迁移,启动窗口一闪而过,启动失败的解决办法。

笔者手动部署一个web项目到Tomcat/webapps/目录下,成功运行.后来,项目结束,我把webapps下的姓项目文件夹删除.重启Tomcat时,运行...\apache-tomcat-8.5.41\bin\startup.bat发现启动出窗口(黑色命令行窗口)一闪而过,tomcat启动失败,无法启动. 先可以查看Tomcat本地日志信息, 日志信息的格式: catalina.YYYY-MM-DD.log YYYY-MM-DD 是当天的日期.我的...\apache-tomcat-8.5.