《二十二》对打包时间和打包体积进行分析

对打包时间的分析:

可以使用 SpeedMeasurePlugin 插件来分析每个 Loader 和每个 Plugin 消耗的打包时间。

  1. 新建 index.htmlsrc/index.csssrc/index.js 文件,并编写代码。

    // index.html
    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Document</title>
    </head>
    <body>
      <div id="root"></div>
    </body>
    </html>
    
    src/index.css
    body {
      width: 100%;
      height: 100%;
    }
    
    .container {
    	width: 100%;
      height: 100%;
      background: black;
    }
    
    .title {
      color: white;
      font-size: 24px;
    }
    
    // src/index.js
    import './index.css'
    
    console.log('index')
    
  2. 运行 webpack 命令进行打包,只能看到总的打包时间。
    在这里插入图片描述

  3. 安装 SpeedMeasurePlugin 插件:npm install speed-measure-webpack-plugin --save-dev

  4. webpack.config.js 配置文件中进行配置。

    // webpack.config.js
    const HtmlWebpackPlugin = require('html-webpack-plugin');
    const config = {
      mode: 'development',
      module: {
        rules: [
          {
            test: /\.css$/,
            use: ["style-loader", "css-loader"],
          },
        ],
      },
      plugins: [
        new HtmlWebpackPlugin({
          template: './index.html',
        }),
      ]
    }
    module.exports = config
    
    // 引入 SpeedMeasurePlugin 插件
    const SpeedMeasurePlugin = require('speed-measure-webpack-plugin')
    // 实例化 SpeedMeasurePlugin 类
    const smp = new SpeedMeasurePlugin()
    // 调用 SpeedMeasurePlugin 实例对象的 wrap() 方法包裹要导出的 Webpack 的配置
    smp.wrap(config)
    
  5. 再次运行 webpack 命令进行打包,可以看到总的打包时间和每个 Loader、Plugin 消耗的打包时间。
    在这里插入图片描述

对打包体积的分析:

直接使用打包命令:

官方针对打包命令提供了一个参数 profile,可以将打包后文件的信息生成一个文件,就可以在这个文件中查看打包后文件的信息。

  1. 在打包命令后面跟上 --profile --json=stats.json,表示将打包后文件的相关信息打包后为 JSON 格式,并且该文件名为 stats.json。运行 webpack --profile --json=stats.json 命令进行打包,会发现,在项目的根目录下生成了 stats.json 文件。
    请添加图片描述
  2. 但其实 JSON 文件看起来也不是那么直观,可以访问 http://webpack.github.io/analyse/ 网站,将 JSON 文件上传上去转化为一个可视化的界面来查看。
    在这里插入图片描述
    在这里插入图片描述

使用 WebpackBundleAnalyzer 插件:

WebpackBundleAnalyzer 插件会在打包成功之后,开启一个本地服务,就能看到打包后文件的大小。

  1. 安装 WebpackBundleAnalyzer 插件:npm install webpack-bundle-analyzer --save-dev
  2. 在 Webpack 配置文件中进行配置。
    const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer')
    
    module.exports = {
        plugins: [
            new BundleAnalyzerPlugin()
        ]
    }
    
  3. 运行 webpack 命令进行打包,会开启一个本地服务,自动在浏览器中显示打包后文件的相关信息。
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值