前端性能优化(二)

简介: 前端性能优化(二)

为什么要进行前端性能优化?

  1. 提升用户体验:网页加载速度快、响应迅速可以使用户更加愿意停留在您的网站上。快速的用户界面可以提高用户满意度,使他们更容易完成所需的操作。
  2. 提高页面的可访问性:优化性能通常也意味着减少了页面的加载时间,这有助于在网络连接较慢或设备性能较差的情况下仍然为用户提供良好的访问体验。
  3. 增加网站流量和搜索排名:搜索引擎对网页加载速度有所重视,快速的网站通常在搜索结果中排名更高。此外,用户更喜欢加载速度快的网站,这也有助于提高页面的转化率。
  4. 减少资源浪费:优化前端性能通常意味着减少了不必要的HTTP请求、压缩和缓存静态资源等,这可以减少服务器和网络资源的使用,从而降低运营成本。

在上篇文章中我们讲了前端性能优化的四个点,今天我们来继续分享

5. 使用精灵图 (雪碧图)  --- 有效减少http请求

什么是精灵图呢?为什么我们使用精灵图可以有效减少http请求?我们先来看一个例子。

精灵图(雪碧图,Sprite Sheet)是一种将多个小图片(通常是图标或小图像)合并到一个单一的图像文件中的技术。它最初是为了提高网页或游戏的性能而设计的,因为加载一个大图像比加载多个小图像要快。

精灵图的优点:

  1. 减少HTTP请求:合并多个图像到一个文件中,可以减少HTTP请求的次数,从而提高页面加载速度。
  2. 提高渲染效率:当需要使用精灵图上的图像时,只需设置背景位置和大小,而不是单独加载和渲染每个图像,这可以减少浏览器的渲染时间。

我们打开豆瓣的官网:

image.png

来看看豆瓣的一个列表,我们通过检查可以发现,这里的每一项都是一张图片,而通过手段去设置背景位置和大小,将每一项的文本显示出来,这就是精灵图的一个经典应用。这达到了减少请求的作用,如果这里并不是一张大图,而是八张小图,那么我们就需要进行八次http请求,而使用精灵图只需要进行一次。

6. 压缩文件

1. 图片压缩:

图片通常是网页中占用大量空间的文件类型,因此图片压缩是非常关键的一步。

  • 无损压缩:使用工具如ImageOptimTinyPNGSquoosh等,这些工具可以在几乎不损失图片质量的情况下大幅减少文件大小。
  • 有损压缩:对于需要的图片,可以考虑使用有损压缩工具如JPEG Optimizer(用于JPEG图像)或ImageMagick(用于多种格式)。

2. CSS和JS压缩:

  • 压缩工具:使用工具如UglifyJSTerser对JavaScript进行压缩,使用CSSNanoCleanCSS对CSS进行压缩。
  • CSS预处理器和模块化:使用Less、Sass等预处理器,并结合工具如Autoprefixer来自动添加浏览器前缀,然后再进行压缩。

3. HTML压缩:

  • HTML压缩工具:使用工具如HTMLMinifier来压缩HTML文件,去除空格、注释、删除不必要的属性等。

4. 字体优化:

  • 字体子集化:使用工具如Font SquirrelFont Subsetter,仅包含需要的字符,以减少字体文件大小。
  • 字体格式选择:选择合适的字体格式(如WOFF、WOFF2),以便在不同的设备和浏览器中提供最佳的兼容性和性能。

5. 文件合并:

  • 资源合并:将多个小文件合并为一个大文件(如CSS和JS文件),减少HTTP请求次数。但要注意,合并文件的过程需要考虑文件的依赖关系,以避免潜在的问题。

7. 使用webp格式的图片 (更优秀的图像压缩算法)

使用 WebP 格式的图片是前端优化中非常有效的方式,因为它提供了比 JPEG 和 PNG 更优秀的图像压缩算法,可以显著减少图片的文件大小,同时保持高质量的图像输出。

8. if-else vs  switch-case

let color = 'pink'
if (color = 'red') {
    
} else if (color = 'blue') {
    
} else if (color = 'green') {
    
} else if (color = 'yellow') {
    
} else if (color = 'pink') {
    
} else {
    
}
switch (color) {
    case 'red':
        
        break
    case 'blue':
        
        break
    case 'green':
        
        break
    case 'yellow':
        
        break
    case 'pink':
        
        break
    default:
}

如这段代码,我们使用哪一个语句造成的性能消耗更多呢?

我们先来看看if-else语句,这里我们的color为pink,if-else语句开始执行时,从上往下,直到找到color='pink'为止,如果当判断的语句够多时,多执行一些没有必要的代码是十分浪费时间的。

如果是 switch-case语句的话,当我们将pink传进去时,switch语句会直接去找到 case的值为pink,而不必从上往下查找,去执行多余的代码。

9.css 选择器复杂性

我们使用选择器的复杂性应该越低越好,我来举一个例子:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #app .text p{
            
        }
    </style>
</head>
<body>
    <div id="app">
        <div class="text">
            <p>hello</p>
        </div>
    </div>
</body>
</html>

如果我们通过这种选择器的方式去拿到<p>hello</p>,那么会造成十分不必要的性能消耗,先会去查询所有的p标签,然后再去查询在.text下的p标签,最后再去查询写在#app下的。

与其通过这种方式去添加样式,我们不如直接给这个p标签去设置一个类名,这样就能减少资源消耗。

10. 图片懒加载

图片懒加载是一种特定的懒加载技术,主要用于延迟加载网页中的图片,只有当图片即将进入用户的视野或用户即将浏览到它们时才进行加载。这种技术对于提高页面加载速度和减少带宽消耗特别有用。

图片懒加载的优势:

  1. 提高页面加载速度
  • 减少了初始加载时所需的图片数量和大小,加快了页面加载速度。
  1. 节省带宽
  • 只加载用户即将浏览的图片,减少了不必要的带宽消耗。
  1. 改善用户体验
  • 用户可以更快地看到页面的核心内容,提高了页面的响应性和用户满意度。
  1. 降低服务器负载
  • 减少了不必要的图片请求,降低了服务器的负载和成本。
相关文章
|
1月前
|
前端开发 JavaScript UED
深入了解前端性能优化:提高用户体验的关键
【10月更文挑战第9天】深入了解前端性能优化:提高用户体验的关键
45 5
|
1月前
|
缓存 前端开发 JavaScript
前端性能优化:从基础到进阶的实践指南
【10月更文挑战第4天】在前端开发中,性能优化至关重要,尤其随着Web应用的复杂化,用户对加载速度和响应性的要求日益提高。本文从基础知识入手,涵盖代码压缩、图片优化及缓存策略,并深入探讨代码拆分、懒加载和Web Workers等进阶技巧,帮助开发者全面提升Web应用的用户体验。通过这些方法,不仅能够减少页面加载时间,还能提升响应性和渲染性能,为用户提供更流畅的使用体验。
59 1
|
8天前
|
编解码 前端开发 JavaScript
从入门到精通:揭秘前端开发中那些不为人知的优化秘籍!
前端开发是充满无限可能的领域,从初学者到资深专家,每个人都追求更快、更稳定、更用户体验友好的网页。本文介绍了四大优化秘籍:1. HTML的精简与语义化;2. CSS的优雅与高效;3. JavaScript的精简与异步加载;4. 图片与资源的优化。通过这些方法,可以显著提升网页性能和用户体验。
14 3
|
17天前
|
缓存 前端开发 JavaScript
前端性能优化:Webpack与Babel的进阶配置与优化策略
【10月更文挑战第28天】在现代Web开发中,Webpack和Babel是不可或缺的工具,分别负责模块打包和ES6+代码转换。本文探讨了它们的进阶配置与优化策略,包括Webpack的代码压缩、缓存优化和代码分割,以及Babel的按需引入polyfill和目标浏览器设置。通过这些优化,可以显著提升应用的加载速度和运行效率,从而改善用户体验。
35 6
|
19天前
|
缓存 监控 前端开发
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第26天】前端工程化是现代Web开发的重要趋势,通过将前端代码视为工程来管理,提高了开发效率和质量。本文详细对比了Webpack和Gulp两大主流构建工具的选择与配置优化,并提供了具体示例代码。Webpack擅长模块化打包和资源管理,而Gulp则在任务编写和自动化构建方面更具灵活性。两者各有优势,需根据项目需求进行选择和优化。
48 7
|
18天前
|
缓存 前端开发 JavaScript
前端工程化:Webpack与Gulp的构建工具选择与配置优化
【10月更文挑战第27天】在现代前端开发中,构建工具的选择对项目的效率和可维护性至关重要。本文比较了Webpack和Gulp两个流行的构建工具,介绍了它们的特点和适用场景,并提供了配置优化的最佳实践。Webpack适合大型模块化项目,Gulp则适用于快速自动化构建流程。通过合理的配置优化,可以显著提升构建效率和性能。
31 2
|
25天前
|
缓存 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
34 3
|
24天前
|
存储 缓存 算法
前端算法:优化与实战技巧的深度探索
【10月更文挑战第21天】前端算法:优化与实战技巧的深度探索
20 1
|
24天前
|
缓存 前端开发 JavaScript
如何优化前端资源
如何优化前端资源
|
25天前
|
监控 前端开发 JavaScript
前端性能优化:打造流畅用户体验的秘籍
【10月更文挑战第20天】前端性能优化:打造流畅用户体验的秘籍
28 2