重绘和重排
- 重排(重构/回流/Reflow):当渲染树的一部分必须更新而且节点的尺寸发生了变化,浏览器会使渲染树中受到影响的部分失效,并从新构造渲染树。
- 重绘(Repaint):是在一个元素的外观被改变所触发的浏览器行为,浏览器会根据元素的新属性从新绘制,使元素呈现新的外观。好比改变某个元素的背景色、文字颜色、边框颜色等等
重排
- 元素宽度、高度改变
- 新增、删除可见dom元素
- 元素的位置改变
- 浏览器窗口尺寸改变
- 填充内容的改变,好比文本的改变或图片大小改变而引发的计算值宽度和高度的改变
如何避免触发回流和重绘
- 避免频繁使用 style,而是采用修改
class
的方式。
- 将动画效果应用到
position
属性为absolute
或fixed
的元素上。
- 也能够先为元素设置
display: none
,操做结束后再把它显示出来。由于在display
属性为none
的元素上进行的DOM操做不会引起回流和重绘
- 使用
createDocumentFragment
进行批量的 DOM 操做。
- 对于 resize、scroll 等进行防抖/节流处理。
- 避免频繁读取会引起回流/重绘的属性,若是确实须要屡次使用,就用一个变量缓存起来。
- 利用 CSS3 的
transform
、opacity
、filter
这些属性能够实现合成的效果,也就是GPU
加速。
欢迎关注本站公众号,获取更多信息