最全的前端性能优化手段回答

2023-11-16

前端性能优化手段

参考答案:

前端性能优化手段从以下几个方面入手:加载优化、执行优化、渲染优化、样式优化、脚本优化

1.加载优化: 减少HTTP请求、缓存资源、压缩代码、无阻塞、首屏加载、按需加载、预加载、压缩图像、减少Cookie、避免重定向、异步加载第三方资源

2.执行优化: CSS写在头部,JS写在尾部并异步、避免img、iframe等的src为空、尽量避免重置图像大小、图像尽量避免使用DataURL

3.渲染优化: 设置viewport、减少DOM节点、优化动画、优化高频事件、GPU加速

4.样式优化: 避免在HTML中书写style、避免CSS表达式、移除CSS空规则、正确使用display:display、不滥用float等

5.脚本优化: 减少重绘和回流、缓存DOM选择与计算、缓存.length的值、尽量使用事件代理、尽量使用id选择器、touch事件优化

解析:

一.加载优化

1.减少HTTP请求:尽量减少页面的请求数(首次加载同时请求数不能超过4个),移动设备浏览器同时响应请求为4个请求(Android支持4个,iOS5+支持6个)

① 合并CSS和JS
② 使用CSS精灵图
2.缓存资源:使用缓存可减少向服务器的请求数,节省加载时间,所有静态资源都要在服务器端设置缓存,并且尽量使用长缓存(使用时间戳更新缓存)

① 缓存一切可缓存的资源
② 使用长缓存
③ 使用外联的样式和脚本
3.压缩代码:减少资源大小可加快网页显示速度,对代码进行压缩,并在服务器端设置GZip

① 压缩代码(多余的缩进、空格和换行符)
② 启用Gzip
4.无阻塞:头部内联的样式和脚本会阻塞页面的渲染,样式放在头部并使用link方式引入,脚本放在尾部并使用异步方式加载

5.首屏加载:首屏快速显示可大大提升用户对页面速度的感知,应尽量针对首屏的快速显示做优化

6.按需加载:将不影响首屏的资源和当前屏幕不用的资源放到用户需要时才加载,可大大提升显示速度和降低总体流量(按需加载会导致大量重绘,影响渲染性能)

① 懒加载
② 滚屏加载
③ Media Query加载
7.预加载:大型资源页面可使用Loading,资源加载完成后再显示页面,但加载时间过长,会造成用户流失

① 可感知Loading:进入页面时Loading
② 不可感知Loading:提前加载下一页
8.压缩图像:使用图像时选择最合适的格式和大小,然后使用工具压缩,同时在代码中用srcset来按需显示(

过度压缩图像大小影响图像显示效果)

① 使用TinyJpg和TinyPng压缩图像
② 使用CSS3、SVG、IconFont代替图像
③ 使用img的srcset按需加载图像
④ 选择合适的图像:webp优于jpg,png8优于gif
⑤ 选择合适的大小:首次加载不大于1014kb、不宽于640px
⑥ PS切图时D端图像保存质量为80,M端图像保存质量为60
9.减少Cookie:Cookie会影响加载速度,静态资源域名不使用Cookie

10.避免重定向:重定向会影响加载速度,在服务器正确设置避免重定向

11.异步加载第三方资源:第三方资源不可控会影响页面的加载和显示,要异步加载第三方资源

二.执行优化

1.CSS写在头部,JS写在尾部并异步
2.避免img、iframe等的src为空:空src会重新加载当前页面,影响速度和效率
3.尽量避免重置图像大小:多次重置图像大小会引发图像的多次重绘,影响性能
4.图像尽量避免使用DataURL:DataURL图像没有使用图像的压缩算法,文件会变大,并且要解码后再渲染,加载慢耗时长

三.渲染优化

1.设置viewport:HTML的viewport可加速页面的渲染

<meta name="viewport" content="width=device-width, user-scalable=no,
initial-scale=1, minimum-scale=1, maximum-scale=1">

2.减少DOM节点:DOM节点太多影响页面的渲染,尽量减少DOM节点

3.优化动画

① 尽量使用CSS3动画
② 合理使用requestAnimationFrame动画代替setTimeout
③ 适当使用Canvas动画:5个元素以内使用CSS动画,5个元素以上使用Canvas动画,iOS8+可使用WebGL动画
4.优化高频事件:scroll、touchmove等事件可导致多次渲染

函数节流
函数防抖
使用requestAnimationFrame监听帧变化:使得在正确的时间进行渲染
增加响应变化的时间间隔:减少重绘次数
5.GPU加速:使用某些HTML5标签和CSS3属性会触发GPU渲染,请合理使用(过渡使用会引发手机耗电量增加)

① HTML标签:video、canvas、webgl
② CSS属性:opacity、transform、transition

4.样式优化

1.避免在HTML中书写style
2.避免CSS表达式:CSS表达式的执行需跳出CSS树的渲染
3.移除CSS空规则:CSS空规则增加了css文件的大小,影响CSS树的执行
4.正确使用display: display会影响页面的渲染
① display:inline后不应该再使用float、margin、padding、width和height
② display:inline-block后不应该再使用float
③ display:block后不应该再使用vertical-align
④ display:table-*后不应该再使用float和margin
5.不滥用float:float在渲染时计算量比较大,尽量减少使用
6.不滥用Web字体:Web字体需要下载、解析、重绘当前页面,尽量减少使用
7.不声明过多的font-size:过多的font-size影响CSS树的效率
8.值为0时不需要任何单位:为了浏览器的兼容性和性能,值为0时不要带单位
9.标准化各种浏览器前缀
① 无前缀属性应放在最后
② CSS动画属性只用-webkit-、无前缀两种
③ 其它前缀为-webkit-、-moz-、-ms-、无前缀四种:Opera改用blink内核,-o-已淘汰
10.避免让选择符看起来像正则表达式:高级选择符执行耗时长且不易读懂,避免使用

5.脚本优化

1.减少重绘和回流
① 避免不必要的DOM操作
② 避免使用document.write
③ 减少drawImage
④ 尽量改变class而不是style,使用classList代替className
2.缓存DOM选择与计算:每次DOM选择都要计算和缓存
3.缓存.length的值:每次.length计算用一个变量保存值
4.尽量使用事件代理:避免批量绑定事件
5.尽量使用id选择器:id选择器选择元素是最快的
6.touch事件优化:使用tap(touchstart和touchend)代替click(注意touch响应过快,易引发误操作) 常用规则

2-5-8原则

在前端开发中,此规则作为一种开发指导思路,针对浏览器页面的性能优化。

用户在2秒内得到响应,会感觉页面的响应速度很快 Fast
用户在2~5秒间得到响应,会感觉页面的响应速度还行 Medium
用户在5~8秒间得到响应,会感觉页面的响应速度很慢,但还可以接受 Slow
用户在8秒后仍然无法得到响应,会感觉页面的响应速度垃圾死了

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

最全的前端性能优化手段回答 的相关文章

随机推荐

  • Python界面 可视化开发(python3+PyQt5+Qt Designer)

    前言 以前制作一个Python窗体界面 我都是用GUI窗口视窗设计的模块Tkinter一点一点敲出来的 今天朋友问我有没有Python窗体的设计工具 用鼠标拖拖 就能完成窗体设计 我查了查相关资料 果然有一款好用的工具 Qt Designe
  • Q3.Numpy_统计分析-排序、去重和重复、搜索和计数函数

    Part 1 排序函数 numpy排序方式主要分为直接排序和间接排序两种 直接排序是指对数值直接进行排序 间接排序是指根据一个或多个键对数据集进行排序 在numpy中 直接排序常用sort 函数 间接排序常用argsort 函数和lexso
  • 官方YOLOV5的torch模型->ONNX模型->RKNN模型

    1 环境配置 1 1 RKNN Toolkit2的环境配置 下载RKNN Toolkit2 git clone https github com rockchip linux rknn toolkit2 git 打开一个终端命令行窗口 安装
  • C++primer(第五版)---14章(重载运算与类型转换)

    目录 编辑 重载运算符的基本概念 调用重载运算符 而有些运算符不应该被重载 应该保持与内置类型一致的含义 是否成员成员函数 重载io lt lt 和 gt gt 运算符 重载 lt lt 运算符 重载 gt gt 运算符 算术运算符 关系运
  • python英文(无空格)文本分词模块wordninja使用

    在NLP中 数据清洗与分词往往是很多工作开始的第一步 大多数工作中只有中文语料数据需要进行分词 现有的分词工具也已经有了很多了 这里就不再多介绍了 英文语料由于其本身存在空格符所以无需跟中文语料同样处理 如果英文数据中没有了空格 那么应该怎
  • react在移动端的自适应布局

    1 移动端基本可以无阻碍的进行flex的弹性布局 这边对flex就不进行深究 2 可以进行依据窗口进行vw vh vmin vmax单位的布局 1 vw vh vmin vmax 是一种视窗单位 也是相对单位 它相对的不是父节点或者页面的根
  • Android USB Camera(1) : 调试记录

    1 前言 前段时间调试了一个uvc摄像头 这里做下记录 硬件平台为mt6735 软件平台为android 5 0 2 底层配置 UVC全称是usb video class 一种usb视频规范 所有遵循uvc协议的摄像头都不需要安装额外的驱动
  • integer conversion resulted in a change of sign

    Type 69 D integer conversion resulted in a change of sign MDK 出现 68 D integer conversion resulted in a change of sign 在K
  • 三行代码实时追踪你的手,只要有浏览器就够了

    栗子 发自 凹非寺 量子位 报道 公众号 QbitAI Are You OK O K 人脸不管做了多么一言难尽的表情 五官也不太会四处乱跑 手就不一样了 手势百媚千娇 镜头看到的画面就百媚千娇 所以 AI怎么识别手呢 一位叫做Victor
  • Java获取月份天数错误

    之前编写获取日期函数如下 获取某年某月有多少天 return 该月的天数 public static int getDaysAboutMonth int year int month Calendar c Calendar getInsta
  • 电力电子转战数字IC——我的IC面试(2022.10.14更新)

    目录 感谢信 HKWS10 14面试 25mins JXC10 13面试 30mins JDSK9 23面试 42mins 快速的自我介绍 介绍一下这个MCDF的项目 你这里写SV搭建的验证环境 和UVM搭建的有什么区别吗 你这里写了覆盖率
  • 正视周期,创业在衰退中砥砺前行

    比衰退更重要的是 早期投资机构正在面临结构性机遇 数科星球原创 作者丨苑晶 编辑丨大兔 周期 犹如一只隐形的手 在2023年影响着芸芸众生 从经济周期 行业周期再到货币周期 这个隐形的手牵动着消费者需求 产业链变迁 政策变动等多种因素 亦牵
  • 12.SpringBoot整合mybatis实现插入操作

    本文基于10 springboot整合mybatis环境 默认环境配置好的 下面进入正题 首先查看以下数据库表有什么内容 然后 在EmpMapper中定义插入方法 并在emp xml中加入insert语句 这里推荐使用navicat复制其中
  • 概率图论:了解概率分布、概率独立性和随机化

    作者 禅与计算机程序设计艺术 概率图模型 Probabilistic Graphical Model PGM 是现代统计学习中的一个重要工具 它通过描述变量间的依赖关系和概率分布来对复杂系统进行建模 概率图模型由两部分组成 一是概率模型 它
  • QPoint与QPointF的区别

    QPointF类使用浮点精度定义平面中的点 QPoint类使用整数精度定义平面中的点
  • C语言链表嵌套链表学生成绩管理系统

    一阶段考核标准 用C语言链表嵌套链表学生成绩管理系统 链表A 每个节点存放一个新的链表B1 B2 B3 B4 B5的头结点 场景 一个年级 相当链表A 该年级5个班 每个班5个人 相当于链表B1 B5 做一个学生成绩管理系统学生成绩有语文
  • java版工程管理系统Spring Cloud+Spring Boot+Mybatis实现工程管理系统源码

    工程项目管理软件 工程项目管理系统 对建设工程项目管理组织建设 项目策划决策 规划设计 施工建设到竣工交付 总结评估 运维运营 全过程 全方位的对项目进行综合管理 工程项目各模块及其功能点清单 一 系统管理 1 数据字典 实现对数据字典标签
  • Java中transient关键字的详细总结

    目录 一 概要介绍 1 序列化 2 为什么要用transient关键字 3 transient的作用 二 transient使用总结 三 使用场景 一 概要介绍 本文要介绍的是Java中的transient关键字 transient是短暂的
  • the left operand of ** is a garbage value

    CapLocation location 0 if segmentedControl tag SegmentControlTag if segmentIndex 0 location CapLeft else if segmentIndex
  • 最全的前端性能优化手段回答

    前端性能优化手段 参考答案 前端性能优化手段从以下几个方面入手 加载优化 执行优化 渲染优化 样式优化 脚本优化 1 加载优化 减少HTTP请求 缓存资源 压缩代码 无阻塞 首屏加载 按需加载 预加载 压缩图像 减少Cookie 避免重定向