随着应用的不断迭代,webpack应用最常见的两个问题就是:
有一个很简单的划分方式,就是以构建(build)为分界线,分成前向治理和后向治理:
我们的治理方向,就是围绕前向治理和后向治理。
前向治理的核心概念,就是一个字 快
,目的就是提升构建速度,市面上大部分webpack优化文章都是这一类提升构建速度的文章,所以这里就简单介绍一些不错的实践
数据先行,通过speed-measure-webpack-plugin[1]采集性能指标,可以得到webpack在整个编译过程中在loader、plugin上花费的时间,基于该数据可以专项的进行优化和治理。
如果通过SMP分析得知在loader编译过程耗时较多,那么可以在核心loader,例如babel-loader中添加缓存。
{
loader: 'babel-loader',
options: {
cacheDirectory: true
}
}
复制代码
如果通过SMP分析得知在loader编译过程耗时较多,还可以通过使用happyPack[2],开启多线程编译,提升开发效率。
dll可以简单理解成提前打包,例如lodash、echarts等大型npm包,可以通过dll将其提前打包好,这样在业务开发过程中就不用再重复去打包了,可以大幅缩减打包时间。
webpack5利用 持久缓存
来提高构建性能,或许升级webpack后,前述的各种优化,都将成为历史。
后向治理主要保证构建结果的质量
很常见的就是webpack-bundle-analyzeer[3],提供打包结果的可视化展示,如上图给予的决策帮助是:
业务开发过程中,随着业务迭代,经常有些文件、模块及代码被废弃,这些废弃代码随着时间推移,将逐渐变为历史包袱,所以针对构建后结果,我们要做的就是清理其中的deadcode。
前面webpack-bundle-analyzeer虽然是最常用的插件,但依旧有一些缺陷:
例如上图:
tree-sharking大家都了解,摇掉不需要的代码,做为最终的输出结果,但反过来说,这些废弃代码依旧在本地真实不虚的存在着。
所以如何能准确的清理掉deadcode呢?这就需要通过webpack的 统计信息(stats)
来进行更细节的分析
stats[4]是通过 webpack 编译源文件时,生成的包含有关于模块的统计数据的 JSON 文件,这些统计数据不仅可以帮助开发者来分析应用的依赖图表,还可以优化编译的速度。
webpack --profile --json > compilation-stats.json
复制代码
通过上述全局命令即可输出统计信息,例如:
{
"version": "1.4.13", // Version of webpack used for the compilation
"hash": "11593e3b3ac85436984a", // Compilation specific hash
"time": 2469, // Compilation time in milliseconds
"filteredModules": 0, // A count of excluded modules when `exclude` is passed to the `toJson` method
"assetsByChunkName": {
// Chunk name to emitted asset(s) mapping
"main": "web.js?h=11593e3b3ac85436984a",
"named-chunk": "named-chunk.web.js",
"other-chunk": [
"other-chunk.js",
"other-chunk.css"
]
},
"assets": [
// A list of asset objects
],
"chunks": [
// A list of chunk objects
],
"modules": [
// A list of module objects
],
"errors": [
// A list of error strings
],
"warnings": [
// A list of warning strings
]
}
复制代码
通过对modules和chunks加以分析,就可以得到webpack完整的依赖关系,从而梳理出废弃文件及废弃代码,同时也可以根据业务形态进行定制。
前面提到分析stats.json,但因为是原始数据,数据量比较大,有一定处理和清洗成本,所以可以使用开源的webpack-deadcode-plugin[5]这个插件
通过webpack-deadcode-plugin,可以快速筛选出:
lint可以快速的扫描出未使用的变量,这能够极大的提升我们的deadcode清理效率。
顿时整个应用干干净净,舒舒服服!
[1]
speed-measure-webpack-plugin: https://github.com/stephencookdev/speed-measure-webpack-plugin
[2]
happyPack: https://github.com/amireh/happypack
[3]
webpack-bundle-analyzeer: https://github.com/webpack-contrib/webpack-bundle-analyzer
[4]
stats: https://webpack.js.org/api/stats/
[5]
webpack-deadcode-plugin: https://github.com/MQuy/webpack-deadcode-plugin
[6]
speed-measure-webpack-plugin: https://github.com/stephencookdev/speed-measure-webpack-plugin
[7]
happyPack: https://github.com/amireh/happypack
[8]
webpack-bundle-analyzeer: https://github.com/webpack-contrib/webpack-bundle-analyzer
[9]
stats: https://webpack.js.org/api/stats/
[10]
webpack-deadcode-plugin: https://github.com/MQuy/webpack-deadcode-plugin
最后