1.webpack 3.11升级4.26
为了提升打包效率,在webpack3.11基础之上做了升级,webpack4.0发布以来,零配置的webpack对项目本身提供的“打包”和“压缩”功能已经做了优化,如果在项目开始使用4.0而不用vue-cli的默认配置,遇到的问题或许能少一些。
2. 安装/升级依赖
这些依赖有的是在build过程中发现依赖有新的替换或者报错,逐步替换的,如果想遇到多个坑,可以先把webpack、webpack-cli升级到对应版本
devDependencies:
"extract-text-webpack-plugin": "^4.0.0-beta.0" "html-webpack-plugin": "^4.0.0-beta.14" "mini-css-extract-plugin": "^0.9.0" (旧的optimize-css-assets-webpack不支持了) "preload-webpack-plugin": "^3.0.0-beta.4" "script-ext-html-webpack-plugin": "^2.1.3" "vue-loader": "^15.3.0" "webpack": "^4.26.1" "webpack-cli": "^3.1.2" "webpack-dev-server": "^3.2.1" "script-ext-html-webpack-plugin": "^2.1.3"
3. 遇到的问题
升级webpack后,build报错:ERROR in ./src/App.vue
Module Error (from ./node_modules/vue-loader/lib/index.js
解决:升级vue-loader至15.3.0,
webpack.base.conf.js添加
const {VueLoaderPlugin} = require('vue-loader') module.exports中添加 plugins:[new VueLoaderPlugin()]
修改配置文件 webpack.prod.conf.js:
webpack.optimize.CommonsChunkPlugin has been removed, please use config.optimization.splitChunks instead.
解决:
webpack.prod.conf.js webpackConfig配置: optimization: { noEmitOnErrors: true, concatenateModules: true, splitChunks: { chunks: 'all', name: 'common', }, runtimeChunk: { name: 'runtime' } } webpack.prod.conf.js webpackConfig配置: optimization:{ namedModules: true },
Plugin could not be registered at ‘html-webpack-plugin-before-html-processing'. Hook was not found.
解决:
npm i preload-webpack-plugin@next -D
Tapable.plugin is deprecated. Use new API on .hooks instead
问题:extract-text-webpack-plugin兼容问题 ,功能:extract css into its own file
解决: 卸载extract-text-webpack-plugin,安装mini-css-extract-plugin
new MiniCssExtractPlugin({ filename: utils.assetsPath('css/[name].[contenthash].css'), allChunks: false, }),
build出错:ERROR in TypeError: Cannot read property ‘hash' of undefined
解决:
去掉这段 //打包计时 const SpeedMeasurePlugin = require("speed-measure-webpack-plugin"); const smp = new SpeedMeasurePlugin();
WARNING in configuration
The ‘mode' option has not been set, webpack will fallback to ‘production' for this value. Set ‘mode' option to ‘development' or ‘production' to enable defaults for each environment.
You can also set it to ‘none' to disable any default behavior. Learn more: https://webpack.js.org/concepts/mode/
解决:webpackConfig添加 mode: ‘production'
Tapable.plugin is deprecated. Use new API on .hooks instead
解决:
npm i --save-dev extract-text-webpack-plugin@next
会下载到 extract-text-webpack-plugin@4.0.0-beta
Error: webpack.optimize.CommonsChunkPlugin has been removed, please use config.o ptimization…
解决:
- 去掉 webpack.optimize.CommonsChunkPlugin相关配置
- webpackConfig中与plugins的同级添加
optimization: { splitChunks: { cacheGroups: { commons: { name: "commons", chunks: "initial", minChunks: 2 } } } },
Unhandled rejection Error: “dependency” is not a valid chunk sort mode
new HtmlWebpackPlugin({ filename: config.build.index, template: 'index.html', inject: true, minify: { removeComments: true, collapseWhitespace: true, removeAttributeQuotes: true }, // necessary to consistently work with multiple chunks via CommonsChunkPlugin chunksSortMode: 'dependency' }),
解决:chunksSortMode改为auto或者注释
至此:npm run build 正常
接下来调npm run dev,直接运行成功
4. 总结
开启cache的情况下,原来打包时间22s左右,现在build最快8s左右
升级思路:
- 卸载webpack旧版本、安装新版本webpack, webpack-cli
- 遇到loader、plugin报错,升级loader、plugin,有的在4.0不支持,需要换成新的
- 卸载 ExtractTextPlugin、删除对应配置,改用 mini-css-extract-plugin
- 配置环境mode
- 其它wenpack3.0优化配置兼容处理
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。