深入理解前端性能优化:从网络到渲染

简介: 网络优化包括减少HTTP请求、使用HTTP/2、开启GZIP压缩和缓存策略。资源加载优化涉及懒加载、预加载和预读取。渲染优化建议使用Critical CSS、减少CSS和JavaScript阻塞以及避免强制同步布局。Service Worker实现离线存储,性能监控使用Lighthouse等工具。动态导入和代码拆分减少初始加载时间,响应式图片适应不同设备。Web Workers处理耗时任务,避免内存泄漏。

1. 网络优化

减少HTTP请求

  • 合并资源:通过合并CSS和JavaScript文件减少请求次数。
  • 资源内联:对于小的CSS和JavaScript,直接内联到HTML中。

使用HTTP/2

  • HTTP/2支持多路复用,减少请求阻塞,提高加载速度。

开启GZIP压缩

服务器端配置,压缩文本资源,减小传输体积。

缓存策略

利用HTTP缓存头,如Cache-Control,设置合适的缓存策略。

2. 资源加载优化

懒加载

只在资源即将进入视口时才加载,适用于图片和视频等。

<img src="placeholder.jpg" data-src="real-image.jpg" class="lazy" />
<script>
document.addEventListener('DOMContentLoaded', function() {
    
  let lazyImages = document.querySelectorAll('.lazy');
  lazyImages.forEach(img => {
    
    img.src = img.dataset.src;
  });
});
</script>

预加载与预读取

使用<link rel="preload">提前加载关键资源。
使用<link rel="prefetch">预读取非关键资源。

3. 渲染优化

Critical CSS

将首屏渲染所需的CSS内联在HTML头部,避免阻塞渲染。

减少CSS和JavaScript的阻塞

  • 使用<link rel="stylesheet" media="print" onload="this.media='all'">延迟非关键CSS加载。
  • 使用asyncdefer属性异步加载JavaScript。
<script async src="script.js"></script>

避免强制同步布局

  • 使用requestAnimationFrame或CSS动画代替复杂的JavaScript动画,减少重排重绘。

图片优化

  • 选择合适的图片格式(如WebP),并使用正确的尺寸和分辨率。

4. Service Worker与离线存储

  • 使用Service Worker实现离线缓存和资源更新。
if ('serviceWorker' in navigator) {
   
  window.addEventListener('load', () => {
   
    navigator.serviceWorker
      .register('/sw.js')
      .then(registration => console.log('SW registered:', registration))
      .catch(error => console.error('SW registration failed:', error));
  });
}

5. 性能监控与分析

  • 使用Lighthouse、WebPageTest或Chrome DevTools等工具进行性能测试和分析。

6. 代码拆分与懒加载

动态导入

利用动态导入(import()表达式)按需加载代码块,减少初始加载时间。

button.onclick = async () => {
   
  const module = await import('./lazyModule.js');
  module.default();
};

路由级别代码拆分

在SPA应用中,利用框架提供的路由级别代码拆分功能,如Vue Router的懒加载。

// Vue Router 示例
const Foo = () => import('./Foo.vue');

const routes = [
  {
    path: '/foo', component: Foo },
];

7. 图像优化

响应式图片

利用<picture>元素或srcset属性,根据设备像素比或视口大小提供不同分辨率的图片。

<picture>
  <source srcset="img/low-res.jpg" media="(max-width: 600px)">
  <source srcset="img/high-res.jpg" media="(min-width: 600px)">
  <img src="img/fallback.jpg" alt="Example">
</picture>

8. Web Workers

将耗时的计算任务移到Web Worker中,避免阻塞主线程,保持UI响应。

// main.js
const worker = new Worker('worker.js');
worker.postMessage([1024, 512]);

// worker.js
self.onmessage = function(e) {
   
  const result = e.data[0] * e.data[1];
  self.postMessage(result);
};

9. 避免内存泄漏

定期清理不再使用的定时器、事件监听器和大型数据结构,防止内存泄漏。

window.addEventListener('resize', handleResize);
// 清理
window.removeEventListener('resize', handleResize);

// 对于setTimeout或setInterval
let timerId = setInterval(() => {
    /*...*/ }, 1000);
clearInterval(timerId);

10. Web Vitals监控

关注LCP(最大内容绘制)、FID(首次输入延迟)和CLS(累计布局偏移)等Web Vitals指标,它们是衡量用户体验的关键指标。

// 使用Web Vitals库进行监控
import {
    getCLS, getFID, getLCP } from 'web-vitals';

getCLS(console.log);
getFID(console.log);
getLCP(console.log);

2500G计算机入门到高级架构师开发资料超级大礼包免费送!

相关文章
|
3天前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
|
7天前
|
缓存 前端开发 JavaScript
前端性能优化:Webpack与Babel的进阶配置与优化策略
【10月更文挑战第28天】在现代Web开发中,Webpack和Babel是不可或缺的工具,分别负责模块打包和ES6+代码转换。本文探讨了它们的进阶配置与优化策略,包括Webpack的代码压缩、缓存优化和代码分割,以及Babel的按需引入polyfill和目标浏览器设置。通过这些优化,可以显著提升应用的加载速度和运行效率,从而改善用户体验。
22 5
|
8天前
|
缓存 监控 前端开发
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第26天】前端工程化是现代Web开发的重要趋势,通过将前端代码视为工程来管理,提高了开发效率和质量。本文详细对比了Webpack和Gulp两大主流构建工具的选择与配置优化,并提供了具体示例代码。Webpack擅长模块化打包和资源管理,而Gulp则在任务编写和自动化构建方面更具灵活性。两者各有优势,需根据项目需求进行选择和优化。
35 7
|
8天前
|
缓存 前端开发 JavaScript
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第27天】在现代前端开发中,构建工具的选择对项目的效率和可维护性至关重要。本文比较了Webpack和Gulp两个流行的构建工具,介绍了它们的特点和适用场景,并提供了配置优化的最佳实践。Webpack适合大型模块化项目,Gulp则适用于快速自动化构建流程。通过合理的配置优化,可以显著提升构建效率和性能。
21 2
|
14天前
|
缓存 监控 前端开发
优化网络应用的性能
【10月更文挑战第21天】优化网络应用的性能
12 2
|
14天前
|
缓存 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
27 3
|
14天前
|
存储 缓存 算法
前端算法:优化与实战技巧的深度探索
【10月更文挑战第21天】前端算法:优化与实战技巧的深度探索
13 1
|
14天前
|
缓存 前端开发 JavaScript
如何优化前端资源
如何优化前端资源
|
14天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于贝叶斯优化CNN-LSTM网络的数据分类识别算法matlab仿真
本项目展示了基于贝叶斯优化(BO)的CNN-LSTM网络在数据分类中的应用。通过MATLAB 2022a实现,优化前后效果对比明显。核心代码附带中文注释和操作视频,涵盖BO、CNN、LSTM理论,特别是BO优化CNN-LSTM网络的batchsize和学习率,显著提升模型性能。
|
14天前
|
监控 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
23 2