目录
自定义预算
超出阈值时显示错误
排除某些资源
限制
总结
首页 web前端 css教程 使用WebPack执行性能预算

使用WebPack执行性能预算

Apr 02, 2025 pm 05:01 PM

Enforcing performance budgets with webpack

现代 Web 应用不再依赖单一的庞大 JavaScript 包。研究表明,较大的包会增加内存使用和 CPU 负载,尤其是在中低端移动设备上。Webpack 提供了多种功能来减小包大小并控制资源加载优先级,其中最重要的是代码分割和性能提示。代码分割将代码分成多个包,按需或并行加载;性能提示在构建时检测包大小是否超过指定阈值,以便进行优化或删除不必要的代码。

Webpack 默认情况下,当资源大小或入口点超过 250KB (244KiB) 时会发出警告,但您可以通过 webpack.config.js 文件中的 performance 对象配置性能提示的显示方式和大小阈值。本文将介绍如何利用此功能作为防止性能下降的第一道防线。

自定义预算

默认的资源和入口点大小阈值可能并不总是符合您的需求,但可以进行配置。例如,一个小型博客的预算可能是资源和入口点各 50KB (48.8KiB)。webpack.config.js 中的相关设置如下:

module.exports = {
  performance: {
    maxAssetSize: 50000,
    maxEntrypointSize: 50000,
  }
};
登录后复制

maxAssetSizemaxEntrypointSize 属性分别控制资源和入口点的阈值大小(单位为字节)。maxEntrypointSize 确保从 entry 对象中列出的文件(通常是 JavaScript 或 Sass 文件)创建的包不超过指定阈值;maxAssetSize 对 Webpack 生成的其他资源(例如图像、字体等)强制执行相同的限制。

超出阈值时显示错误

Webpack 默认在超出预算阈值时发出警告。这对于开发环境足够了,但对于生产环境则不足。您可以通过将 hints 属性添加到 performance 对象并将其设置为 'error' 来触发错误:

module.exports = {
  performance: {
    maxAssetSize: 50000,
    maxEntrypointSize: 50000,
    hints: 'error',
  }
};
登录后复制

hints 属性的其他有效值为 'warning'falsefalse 将完全禁用警告,即使超过了指定的限制。不建议在生产模式下使用 false

排除某些资源

Webpack 对其生成的每种类型的资源都强制执行大小阈值。如果任何一个资源超过了指定的限制,都会抛出错误。例如,如果配置 Webpack 处理图像,那么只要其中一个图像超过了阈值,就会出现错误。

可以使用 assetFilter 属性来控制用于计算性能提示的文件:

module.exports = {
  performance: {
    maxAssetSize: 50000,
    maxEntrypointSize: 50000,
    hints: 'error',
    assetFilter: function(assetFilename) {
      return !assetFilename.endsWith('.jpg');
    },
  }
};
登录后复制

这告诉 Webpack 在运行性能提示计算时,排除任何以 .jpg 结尾的文件。它能够使用更复杂的逻辑来满足各种环境、文件类型和其他资源的条件。

限制

目前的一个限制是,相同的预算阈值应用于所有资源和入口点。换句话说,尚无法根据需要设置多个预算,例如为 JavaScript、CSS 和图像文件设置不同的限制。不过,已经有开放的 pull request 应该会移除此限制。

总结

在项目开始时设置并强制执行性能预算非常有用。它会提醒您注意依赖项的大小,并鼓励您寻找更轻量级的替代方案,以避免超出预算。

但是,性能预算并不止于此!资源大小只是影响性能的众多因素之一,因此仍需要做更多工作来确保提供最佳体验。运行 Lighthouse 测试是了解其他指标以及改进建议的好方法。

以上是使用WebPack执行性能预算的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue团队完成了完成,我知道这是一项巨大的努力,而且很长时间。所有新文档也是如此。

您可以从浏览器获得有效的CSS属性值吗? 您可以从浏览器获得有效的CSS属性值吗? Apr 02, 2025 pm 06:17 PM

我有人写了这个非常合法的问题。 Lea只是在博客上介绍了如何从浏览器中获得有效的CSS属性。那样的是这样。

在CI/CD上有点 在CI/CD上有点 Apr 02, 2025 pm 06:21 PM

我说的“网站”比“移动应用程序”更合适,但我喜欢Max Lynch的框架:

带有粘性定位的堆叠卡和一点点的杂物 带有粘性定位的堆叠卡和一点点的杂物 Apr 03, 2025 am 10:30 AM

前几天,我发现了科里·金尼文(Corey Ginnivan)网站上的这一点,当您滚动时,彼此之间的卡片堆放集。

在WordPress块编辑器中使用Markdown和本地化 在WordPress块编辑器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我们需要直接在WordPress编辑器中向用户显示文档,那么最佳方法是什么?

比较浏览器的响应式设计 比较浏览器的响应式设计 Apr 02, 2025 pm 06:25 PM

这些桌面应用程序中有许多目标是同时在不同的维度上显示您的网站。因此,例如,您可以写作

如何将CSS网格用于粘头和页脚 如何将CSS网格用于粘头和页脚 Apr 02, 2025 pm 06:29 PM

CSS网格是一系列属性的集合,旨在使布局比以往任何时候都容易。像任何东西一样,那里有一点学习曲线,但是网格是

为什么Flex布局中的紫色斜线区域会被误认为是'溢出空间”? 为什么Flex布局中的紫色斜线区域会被误认为是'溢出空间”? Apr 05, 2025 pm 05:51 PM

关于Flex布局中紫色斜线区域的疑问在使用Flex布局时,你可能会遇到一些令人困惑的现象,比如在开发者工具(d...

See all articles