webpack3升级webpack4

webpack3升级webpack4

一、概述

相比于webpack3,webpack4可以零配置运行,打包速度比之前提高了90%,可以直接到ES6的代码进行无用代码剔除,新增的optimization使用简单。
webpack4 设置了默认值,以便无配置启动项目
1)entry 默认值是 ./src/
2)output.path默认值是 ./dist
3) mode 默认值是 production

二、模式mode

webpack4新增了一个mode配置选择,用来表示配置模式的选择情况
  module.exports = {
      mode: 'production' 
  }

包括生产环境production、开发环境devolopment和自定义none这三个选择可
【开发模式】
浏览器调试工具 注释、开发阶段的详细错误日志和提示
快速和优化的增量构建机制 开启 output.pathinfo
在 bundle 中显示模块信息 开启 NamedModulesPlugin
开启 NoEmitOnErrorsPlugin
【生产模式】
启用所有优化代码的功能
更小的bundle大小
去除只在开发阶段运行的代码
关闭内存缓存 Scope hoisting 和 Tree-shaking
开启 NoEmitOnErrorsPlugin
开启 ModuleConcatenationPlugin
开启 optimization.minimize
【none】
禁用所有的默认设置

三、optimization

webpack4开始官方移除了commonchunk插件,改用了optimization属性进行更加灵活的配置,下面是一些常用配置项:

【minimize】

利用unglifyjsWebpackPlugin插件来压缩模块,生产环境下该值默认为true

optimization: {
    minimize: false
 }

【minimier】
可以使用其他插件来执行压缩功能

 const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
module.exports = {
    optimization: {
 	minimizer: [
  	    new UglifyJsPlugin({ /* your config */ })
  	] 
    }
};

【splitChunks】
webpack4默认使用splitChunksPlugin插件来实现代码分割功能,来替代webpack3中的commonChunksPlugin插件

【runtimeChunk】
通过设置 runtimeChunk: true 来为每一个入口默认添加一个只包含 runtime 的 chunk
【noEmitOnErrors】
使用可读的模块标识,方便更好的调试。webpack在开发模式下默认开启,生产模式下默认关闭,用来替代 NamedModulesPlugin 插件

 module.exports = {
  //...
 optimization: {
 namedModules: true 
  }
 };

四、升级

基于vue-cli的项目对webpack配置进行升级
1、升级nodejs
使用 webpack4 时,必须保证 Node.js 版本 >= 8.9.4,因为 webpack4 使用了大量的ES6语法,这些语法在 nodejs新版 v8 中得到了原生支持
2、升级webpack主要部件,包括webpack、webpack-bundle-analyzer、webpack-dev-server、webpack-merge
webpack4版本中 cli 工具分离成了 webpack 核心库 与 webpack-cli 命令行工具两个模块,需要使用 CLI,安装 webpack-cli 至项目中

      cnpm uninstall -D webpack webpack-bundle-analyzer webpack-dev-server webpack-merge
      cnpm install -D webpack webpack-cli webpack-bundle-analyzer webpack-dev-server webpack-merge

3、升级webpack相关插件,包括copy-webpack-plugin、css-loader、eslint-loader、file-loader、html-webpack-plugin、url-loader、friendly-errors-webpack-plugin、optimize-css-assets-webpack-plugin、uglifyjs-webpack-plugin

      cnpm uninstall -D copy-webpack-plugin css-loader eslint-loader file-loader html-webpack-plugin url-loader  friendly-errors-webpack-plugin optimize-css-assets-webpack-plugin uglifyjs-webpack-plugin 
      cnpm install -D copy-webpack-plugin css-loader eslint-loader file-loader html-webpack-plugin url-loader  friendly-errors-webpack-plugin optimize-css-assets-webpack-plugin uglifyjs-webpack-plugin

4、升级vue-loader
vue-loader升级到v15之后,配置和之前相比区别还是比较大的,详细的可参考vue-loader文档,这里我列出此次升级主要涉及的几点改动:
1)升级为v15版本后,需要配合一个plugin才能正常使用

 const VueLoaderPlugin = require('vue-loader/lib/plugin')
 module.exports = {
     plugins: [
         new VueLoaderPlugin()
     ]
 }

2)对于.vue文件中的css模块less的处理,在v14的版本中,需要在vue-loader的配置项中去定义使用的loader,而在v15中,会把style当成一个文件处理,只需在主webpack配置项中去定义需要的loader,省下了不少配置。下面是vue-loader在webpack.base.conf.js文件中的配置。
5、替换webpack相关插件,extract-text-webpack-plugin替换为mini-css-extract-plugin

cnpm uninstall -D extract-text-webpack-plugin
cnpm install -D mini-css-extract-plugin

五、配置

1、webpack.base.conf.js文件,增加node: process.env.NODE_ENV

 module.exports = {
     mode: process.env.NODE_ENV,
 }

2、webpack.prop.conf.js文件
1)将ExtractTextPlugin替换为MiniCssExtraPlugin
2)删除UglifyJsPlugin配置项
3)删除CommonsChunkPlugin配置项
4)添加optimization配置项

posted @ 2020-08-17 00:38  我是粉粉呀  阅读(963)  评论(0编辑  收藏  举报