搜索
首页web前端js教程文本压缩和代码分割和现代图像格式 - 性能优化

Text compression & Code splitting & Modern image formats - Performance optimization

我尝试了以下方法来优化我的业余项目性能:

  1. 文本压缩
  2. 代码分割
  3. 现代图像格式.

分析器

我构建的应用程序使用了 Vite 和 pnpm。现代 Web 构建工具在构建过程中默认自动优化 Web 性能。所以我们可以 pnpm run build 然后 pnpm dlxserve dist。然后使用 Chrome DevTools 的 Lighthouse 作为指南来解决它列出的每个瓶颈。

启用文本压缩

它影响FCPLCP

Lighthouse 建议的第一件事是使用 brgzip 等算法压缩文本。

常见的做法是在发出网络请求时添加 Accept-Encoding: gzip。由于我正在构建的应用程序在本地提供资源,因此我安装了 vite-plugin-compress 来压缩文件。

第 1 步:安装 vite-plugin-compress
第2步:配置vite.config.js文件,添加插件和一些参数。正如 Google 开发人员建议的那样,应该尽可能使用 br(brotliCompress) 而不是 gzip。

例如

viteCompression({
      verbose: true,
      disable: false,
      algorithm: 'brotliCompress',
      ext: '.br',
    }),

第 3 步:运行 pnpm run build 来压缩

它成功压缩了.js和.css文件。

日志:

✨ [vite-plugin-compression]:algorithm=brotliCompress - 压缩文件成功。

Vite 默认会使用 .gzip 压缩文件,但是 brotliCompress 可以做得更好,在构建过程中进行压缩:

使用 gzip 进行视频

vite v5.4.10 构建用于生产...
✓ 改造了 654 个模块。

index-B9QUW17e.css 8.60 kB │ gzip: 2.33 kB
PauseMenu-DjZ95K-6.js 1.77 kB │ gzip: 0.62 kB
索引-ohAKp9W9.js 1,688.05 kB │ gzip: 454.20 kB

Vite-plugin-compression with br

✨ [vite-plugin-compression]:algorithm=brotliCompress - 压缩文件成功:
PauseMenu-DjZ95K-6.js.br 1.73kb / brotli压缩:0.51kb
索引-B9QUW17e.css.br 8.40kb / brotli压缩:1.97kb
索引-ohAKp9W9.js.br 1648.49kb / brotli压缩:345.30kb


减少未使用的 JavaScript

它影响FCPLCP

使用 Google DevTools 中的“覆盖率”选项卡查看未使用字节超过 20kbs 的脚本。

由于我在 React 中使用 Vite,代码拆分 是减少未使用的 JavaScript 的第一件事。

在 React 中,lazy() 可以帮助解决这个问题。

  1. 使用 包裹整个 App 并提供后备 UI,如
    Loading
    ,这会在应用加载时提供后备 UI。
  2. 使用lazy()包装初始页面未使用的组件。例如,对于游戏,当用户按下 Esc 键时,会弹出一个可以打包的菜单。

以现代格式提供图像

Chrome 开发者建议以 AVIFWebP 格式提供图像。我选择 WebP 因为它有更多的跨浏览器支持。

最新版本的 Chrome、Firefox、Safari、Edge 和 Opera 支持 WebP,而 AVIF 支持较为有限。

您可以在我可以使用查看WebP图像格式支持信息。

您可以在 WebP 上安装 cwebp 库,并使用命令 cwebp -q 50 images/flower1.jpg -o images/flower1.webp 将 .png 转换为 .webp 。

此命令以 50 的质量(0 是最差;100 是最好)转换 images/flower1.jpg 文件并将其另存为 images/flower1.webp。

压缩结果相当令人印象深刻。其中一个文件的大小从 3.5 MB 减小到 178kb。即使是低信息强度的也能提供 4 倍压缩。

我们甚至可以编写一个简单的 .bat 脚本,自动将目标文件夹下的所有 .png 图片转换为 .webp 图片。

viteCompression({
      verbose: true,
      disable: false,
      algorithm: 'brotliCompress',
      ext: '.br',
    }),

参考

  • 删除未使用的 JavaScript
  • 使用“覆盖范围”选项卡查看已使用和未使用的 CSS。
  • 以现代格式提供图像。
  • 使用命令行创建 WebP 图像
  • 预编译实用程序
  • WebP 图像格式 - 我可以使用
  • 最大内容油漆 (LCP)
  • 首次内容绘制 (FCP)

以上是文本压缩和代码分割和现代图像格式 - 性能优化的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. JavaScript:开发人员的比较分析Python vs. JavaScript:开发人员的比较分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

Python vs. JavaScript:选择合适的工具Python vs. JavaScript:选择合适的工具May 08, 2025 am 12:10 AM

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript:了解每个的优势Python和JavaScript:了解每个的优势May 06, 2025 am 12:15 AM

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

JavaScript的核心:它是在C还是C上构建的?JavaScript的核心:它是在C还是C上构建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript应用程序:从前端到后端JavaScript应用程序:从前端到后端May 04, 2025 am 12:12 AM

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

Python vs. JavaScript:您应该学到哪种语言?Python vs. JavaScript:您应该学到哪种语言?May 03, 2025 am 12:10 AM

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架:为现代网络开发提供动力JavaScript框架:为现代网络开发提供动力May 02, 2025 am 12:04 AM

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

JavaScript,C和浏览器之间的关系JavaScript,C和浏览器之间的关系May 01, 2025 am 12:06 AM

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr

See all articles

热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

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

热门文章

热工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器