使用 Webpack Bundle Analyzer 分析 JavaScript Bundle

发布于 2022-08-30 12:32:43 字数 2787 浏览 162 评论 0

webpack -bundle-analyzer npm 模块 生成一个交互式 (不要与 Java 的 TreeMap 给定 Webpack 包的类)。此地图对于查找哪些 npm 包对您的包大小增加最多很有用,因此您可以在尝试修剪包大小时查看关注的位置。

设置

首先,您需要安装 Webpack、webpack-cli 和 webpack-bundle-analyzer:

npm install webpack webpack-cli webpack-bundle-analyzer

接下来,让我们安装 Vue Axios 来组装一个简单的 Vue 应用程序。

npm install vue axios

这是一个 src/index.js 文件创建一个简单的 Vue 应用程序。

const Vue = require('vue');
const axios = require('axios');

const url = 'https://jsonplaceholder.typicode.com/users/1';

const app = new Vue({
  data: () => ({ user: '' }),
  template: `
    <div>
      Hello, {{user}}
    </div>
  `,
  mounted: function() {
    axios.get(url).
      then(res => res.data.name).
      then(user => { this.user = user; }).
      catch(err => console.log(err));
  }
});

运行 bundle 分析器

要运行 bundle 分析器,首先你需要使用 --profile--json 用于导出捆绑分析器所需的原始数据的标志:

$ ./node_modules/.bin/webpack --profile --json > stats.json

stats.json 文件看起来像这样:

$ head stats.json 
{
  "errors": [],
  "warnings": [
    "configuration\nThe '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.\nYou can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/configuration/mode/"
  ],
  "version": "4.42.0",
  "hash": "a4433cf21bc97d0be252",
  "time": 269,
  "builtAt": 1583167656248,
  "publicPath": "",
$

接下来,在 stats.json 文件:

$ ./node_modules/.bin/webpack-bundle-analyzer stats.json

Webpack 包分析器将打开一个带有树形图的浏览器窗口:

这是上图的一个例子
读取树形图的方法是 node_modules square 包含它下面的所有内容。 所以捆绑的 node_modules 包含 vue/distaxios,大小 vue/dist平方与捆绑的大小成正比,所以你可以看出 vue/distaxios

而在下面 vue/distaxios/lib/core 是单个文件。Vue 捆绑在一起 vue.runtime.esm.js 文件。 和 axios/lib/core 有几个较小的文件,其中最大的一个是 utils.js

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

起风了

暂无简介

文章
评论
28 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文