查看 webpack 打包后所有组件与组件间的依赖关系,针对多余的包文件过大,
剔除首次影响加载的效率问题进行剔除修改,本次采用的是 ==webpack-bundle-analyzer(可视化视图查看器)==
== 介绍1:webpack-bundle-analyzer(可视化)
==
将捆绑内容表示为方便的交互式可缩放树形图
如下效果图:
模块功能:
- 意识到你的文件打包压缩后中真正的内容
- 找出哪些模块组成最大的大小
- 找到错误的模块
- 优化它!
- 最好的事情是它支持缩小捆绑!它解析它们以获得实际大小的捆绑模块。它也显示他们的gzipped大小!
安装和使用
代码语言:javascript复制npm install --save-dev webpack-bundle-analyzer
在webpack.config.js
中:
let BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
module.exports = {
plugins: [new BundleAnalyzerPlugin()]
}
==BundleAnalyzerPlugin== 构造函数可以采用默认的可选配置对象:
代码语言:javascript复制new BundleAnalyzerPlugin({
// 可以是`server`,`static`或`disabled`。
// 在`server`模式下,分析器将启动HTTP服务器来显示软件包报告。
// 在“静态”模式下,会生成带有报告的单个HTML文件。
// 在`disabled`模式下,你可以使用这个插件来将`generateStatsFile`设置为`true`来生成Webpack Stats JSON文件。
analyzerMode: 'server',
// 将在“服务器”模式下使用的主机启动HTTP服务器。
analyzerHost: '127.0.0.1',
// 将在“服务器”模式下使用的端口启动HTTP服务器。
analyzerPort: 8888,
// 路径捆绑,将在`static`模式下生成的报告文件。
// 相对于捆绑输出目录。
reportFilename: 'report.html',
// 模块大小默认显示在报告中。
// 应该是`stat`,`parsed`或者`gzip`中的一个。
// 有关更多信息,请参见“定义”一节。
defaultSizes: 'parsed',
// 在默认浏览器中自动打开报告
openAnalyzer: true,
// 如果为true,则Webpack Stats JSON文件将在bundle输出目录中生成
generateStatsFile: false,
// 如果`generateStatsFile`为`true`,将会生成Webpack Stats JSON文件的名字。
// 相对于捆绑输出目录。
statsFilename: 'stats.json',
// stats.toJson()方法的选项。
// 例如,您可以使用`source:false`选项排除统计文件中模块的来源。
// 在这里查看更多选项:https: //github.com/webpack/webpack/blob/webpack-1/lib/Stats.js#L21
statsOptions: null,
logLevel: 'info' 日志级别。可以是'信息','警告','错误'或'沉默'。
})
启动服务:
生产环境查看:npm run build --report
或 正常build 即可启动查看器
开发环境查看:webpack -p --progress
或启动正常devServer服务即可启动查看器!
参考资料:
推荐一个网址:在这里,这里介绍了很多webpack优化的工具。
参考资料:https://www.npmjs.com/package/webpack-bundle-analyzer
== 介绍2:webpack官网提供的工具==
webpack提供的一个官方工具,可查看你的项目版本信息,有多少modules,多少chunks,中间有多少错误信息、有多少警告等等,方便你管理、查看。
效果图如下:
操作步骤:
首先,你需要这么启动webpack,执行以下命令行,将会生成一个 stats.json 文件
代码语言:javascript复制webpack --profile --json > stats.json
之后在 官方分析工具里上传文件即可对你的bundle进行分析
==这里注意==:
这里生成的时候,webpack.config.js
文件中不要有console
,打印信息,
否则,他会加入到 stats.json
文件中,从而造成 stats.json
文件错误,并不是一个合格的 JSON
文件,所以官网会解析异常!
^ _ ^ 希望可以帮到你!
参考资料:https://segmentfault.com/a/1190000008663228