歌词滚动之为什么transform比top性能更好?

左侧使用子绝父相 不断更新top 属性,而右侧则使用translate 测试60秒播放查看绘制次数 使用top 方式渲染652 次,使用translate 则只绘制了251

js 复制代码
doms.ul.style.top = `-${offset}px`
// vs
doms.ul.style.transform = `translateY(-${offset}px)`

为什么transform比top少绘那么多次?

这和reflowrepaint有关就是俗称的重排与重绘以及浏览器渲染原理有关

reflow

reflow就是当几何信息变动导致的布局树重新计算以及后续的步骤

哪些操作会导致reflow ? 例如修改几何信息width、height、padding、margin、font-size 包括这里说的top

repaint

repaint 的本质就是重新根据分层信息计算了绘制指令(什么是分层?后续会讲)

我们应该知道重排必然引发重绘对吧,所以不断更新top 必然repaint

览器渲染流程

  1. HTML解析 拿到html文本解析包括不限于html css js,产出DOM树与CSSOM树
  2. 样式计算 样式计算产出带有样式的DOM树
  3. 布局 计算每个节点的几何信息
  4. 分层 现代浏览器为提高性能 将内容易变的分为一层
  5. 绘制 主线程为每个层产生单独的绘制指令
  6. 分块 合成线程对每个图层分块划分为更小的区域由多个线程完成
  7. 光栅化 将每个块变成位图优先处理靠近视口的块
  8. 画 用位图生成quad指引标出应该画到屏幕的那个位置,在此阶段考虑transform animation等

注意 :分块阶段开始是在合成线程处理不会阻塞主线程

分层信息可在控制台layer看

因为几何信息的更改重发reflow 导致repaint

transform不影响布局及绘制指令只在合成线程中画的阶段考虑所以性能更优

其他

  • font-size 更改同样触发reflow 可考虑用scale代替
  • 因为画是在合成线程所以主线程阻塞不会影响到animation与滚动条
相关推荐
若年封尘7 分钟前
告别手写 API 类型:用 openapi-fetch 打造类型安全的前端接口层
前端·安全·openapi-fetch
cypking12 分钟前
二次封装ElementUI日期范围组件:打造带限制规则的Vue2 v-model响应式通用组件
前端·javascript·elementui
A923A13 分钟前
【小兔鲜电商前台 | 项目笔记】第二天
前端·vue.js·笔记·项目·小兔鲜
牧码岛13 分钟前
Web前端之样式中的light-dark函数,从媒体查询到颜色函数,从颜色到图片,light-dark打开CSS新时代、主题切换的暗黑模式到image的正解
前端·css·web·web前端
酉鬼女又兒27 分钟前
零基础快速入门前端蓝桥杯Web考点深度解析:var、let、const与事件绑定实战(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·javascript·职场和发展·蓝桥杯·es6·html5
宁雨桥37 分钟前
前端项目实现光暗主题切换的完整方案
前端
happymaker06261 小时前
vue指令扩展以及监视器的使用
前端·javascript·vue.js
还是大剑师兰特1 小时前
EventBus核心方法用法
javascript·vue.js·大剑师
一只小阿乐1 小时前
vue前端处理流式数据
前端·javascript·ai·大模型·全栈开发·agentai
问道飞鱼1 小时前
【技术方案】面向 Web 系统的《全栈灰度部署方案设计》
前端·全栈·灰度发布