reflow和repaint区别?

作者:zccst

重绘和重排之前也知道,但也没有可以详细了解他们的机制,区别,以及对性能的影响。

A repaint occurs when changes are made to an elements skin that changes
visibility, but do not affect its layout.

Examples of this include outline, visibility, or background color. According
to Opera, repaint is expensive because the browser must verify the visibility of
all other nodes in the DOM tree.

A reflow is even more critical to performance because it involves changes
that affect the layout of a portion of the page (or the whole page).

多谢团队的分享,我才开始了解repaint和reflow,以及对性能的影响。

1. 什么是 repaint 和 reflow?

一个页面由两部分组成:
DOM:描述该页面的结构
render:描述 DOM 节点 (nodes) 在页面上如何呈现

当 DOM 元素的属性发生变化 (如 color) 时, 浏览器会通知 render 重新描绘相应的元素,此过程称为 repaint。

如果该次变化涉及元素布局 (如 width), 浏览器则抛弃原有属性,重新计算并把结果传递给 render 以重新描绘页面元素, 此过程称为
reflow。

这两个过程是很耗费浏览器性能的,从 IE 系列和 Chrome 渲染页面速度上的差距即可看出渲染引擎计算对应值和呈现并不一定高效,
而每次对元素的操作都会发生 repaints 或 reflow,因此编写 DOM 交互时如果不注意就会导致页面性能低下。

页面渲染的过程如下:

1.解析HTML代码并生成一个 DOM 树。

2.解析CSS文件,顺序为:浏览器默认样式->自定义样式->页面内的样式。

3.生成一个渲染树(render tree)。这个渲染树和DOM树的不同之处在于,它是受样式影响的。它不包括那些不可见的节点。

4.当渲染树生成之后,浏览器就会在屏幕上“画”出所有渲染树中的节点。

例子:增删改DOM元素对性能的影响测试

2. 什么情况下会触发浏览器的repaint/reflow?

除了页面在首次加载时必然要经历该过程之外,还有以下行为会触发这个行为:
引用:
1.
DOM元素的添加、修改(内容)、删除( Reflow + Repaint)
2.
仅修改DOM元素的字体颜色(只有Repaint,因为不需要调整布局)
3. 应用新的样式或者修改任何影响元素外观的属性
4.
Resize浏览器窗口、滚动页面
5. 读取元素的某些属性(offsetLeft、offsetTop、offsetHeight、offsetWidth、
scrollTop/Left/Width/Height、clientTop/Left/Width/Height、
getComputedStyle()、currentStyle(in IE))

参考老外的文章:REFLOWS & REPAINTS: CSS PERFORMANCE MAKING
YOUR JAVASCRIPT SLOW?

http://www.stubbornella.org/content/2009/03/27/reflows-repaints-css-performance-making-your-javascript-slow/

    • Resizing the window

    • Changing the font

    • Adding or removing a stylesheet

    • Content changes, such as a user typing text in
      an input box

    • Activation of CSS pseudo classes such as :hover (in IE the activation of
      the pseudo class of a sibling)

    • Manipulating the class attribute

    • A script manipulating the DOM

    • Calculating offsetWidth and offsetHeight

    • Setting a property of the style attribute

3. 怎么优化?

1.
避免在document上直接进行频繁的DOM操作,如果确实需要可以采用off-document的方式进行,具体的方法包括但不完全包括以下几种:

(1) 先将元素从document中删除,完成修改后再把元素放回原来的位置
(2)
将元素的display设置为”none”,完成修改后再把display修改为原来的值
(3)
如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document

用实例证明:对比每次写入DOM和批量写入DOM对性能的影响

2. 集中修改样式
(1) 尽可能少的修改元素style上的属性
(2) 尽量通过修改className来修改样式
(3)
通过cssText属性来设置样式值

实例:每次写入和批量写入的对比

浏览器对于每一个渲染动作并不是立即执行,而是维护了一个渲染任务队列,浏览器会根据具体的需要分批集中执行其中的任务。除了浏览器自身维护的定期调度之外,脚本中的某些操作会导致浏览器立即执行渲染任务,例如读取元素的Layout属性。

3. 缓存Layout属性值

对于Layout属性中非引用类型的值(数字型),如果需要多次访问则可以在一次访问时先存储到局部变量中,之后都使用局部变量,这样可以避免每次读取属性时造成浏览器的渲染。

4.
设置元素的position为absolute或fixed
在元素的position为static和relative时,元素处于DOM树结构当中,当对元素的某个操作需要重新渲染时,浏览器会渲染整个页
面。将元素的position设置为absolute和fixed可以使元素从DOM树结构中脱离出来独立的存在,而浏览器在需要渲染时只需要渲染该元素
以及位于该元素下方的元素,从而在某种程度上缩短浏览器渲染时间,这在当今越来越多的Javascript动画方面尤其值得考虑。

5. 权衡速度的平滑

比如实现一个动画,以1个像素为单位移动这样最平滑,但reflow就会过于频繁,CPU很快就会被完全占用。如果以3个像素为单位移动就会好很多。

6. 不要用tables布局

不要用tables布局的另一个原因就是tables中某个元素一旦触发reflow就会导致table里所有的其它元素
reflow。在适合用table的场合,可以设置table-layout为auto或fixed,这样可以让table一行一行的渲染,这种做法也是为了限制reflow的影响范围

7.
不要在css里面写expression
很多情况下都会触发reflow,如果css里有expression,每次都会重新计算一遍

时间: 2024-12-26 18:35:33

reflow和repaint区别?的相关文章

Reflow、Repaint 性能优化

涉及到操作大量Dom节点及其样式时,有时感觉画面不顺畅,殊不知浏览器亚历山大了.所以我们心里面一定得清楚 Reflow(回流).Repaint(重绘). 浏览器根据每个Dom节点的样式,包括(大小,颜色,位置等等),计算出各个节点应该在页面上展示的位置,占据的空间,这个过程可以称之为Reflow(回流):当节点的位置,空间确定好以后,浏览器便把这些节点按照各自的样子绘制在页面上,这个过程称之为Repaint(重绘): 触发Reflow Dom节点的添加.修改(内容).删除( Reflow + R

css reflow和repaint

浏览器为了重新渲染部分或整个页面,重新计算页面元素位置和几何结构(geometries)的进程叫做 reflow.由于 reflow 是一种浏览器中的用户拦截(user-blocking)操作,所以了解如何减少 reflow 次数,及不同的文档属性(DOM 层级(DOM depth),CSS 效率,不用类型的 style 变化)对 reflow 次数的影响对开发者来说非常必要.有时 reflow 页面中的一个元素会 reflow 它的父元素(译注:这里是复数)以及所有子元素. Yahoo!性能工

性能优化之reflow和repaint

本文主要介绍一下什么是reflow,repaint, 怎样避免它们造成的不良影响, 怎么通过工具查看分析它们. 一.首先对浏览器渲染引擎下网页呈现过程简要说一下: 浏览器的渲染引擎开始解析html构建成DOM树,DOM树是以document对象为根节点,包含所有的html标签, 包括display: none隐藏的,也包括js动态添加的元素. 解析html的同时, 将css文件或者样式元素中的样式解析成CSS Rule Tree,解析时会去掉浏览器不能识别的样式. 根据DOM树和CSSOM来构造

reflow 和 repaint

Reflow(渲染):对于DOM结构中的各个元素都有自己的盒模型,浏览器根据各种样式(浏览器的.开发人员定义的等)来计算,并根据计算结果将元素放到它该出现的位置,这个过程称之为reflow. reflow会影响到dom的结构渲染,同时会触发repaint,他会改变他本身与所有父辈元素(祖先),这种开销是非常昂贵的,导致性能下降是必然的,页面元素越多效果越明显. Repaint(重绘):当各种盒子的位置.大小以及其他属性,例如颜色.字体大小等都确定下来后,浏览器于是便把这些元素都按照各自的特性绘制

reflow和repaint

Web页面运行在各种各样的浏览器当中,浏览器载入.渲染页面的速度直接影响着用户体验 简单地说,页面渲染就是浏览器将html代码根据CSS定义的规则显示在浏览器窗口中的这个过程.先来大致了解一下浏览器都是怎么干活的: 1. 用户输入网址(假设是个html页面,并且是第一次访问),浏览器向服务器发出请求,服务器返回html文件: 2. 浏览器开始载入html代码,发现<head>标签内有一个<link>标签引用外部CSS文件: 3. 浏览器又发出CSS文件的请求,服务器返回这个CSS文

【web性能优化】DOM的reflow 和repaint

回流: 对于DOM结构中的各个元素都有自己的盒子模型,这些都需要浏览器根据各种样式(浏览器的.开发人员定义的等)来计算并根据计算结果将元素放到它该出现的位置,这过程称之为reflow(回流) 重绘: 当各种盒子的位置.大小以及其他属性,例如颜色.字体大小等都确定下来后,浏览器于是便吧这些元素都按照各自的特性绘制了一遍,于是页面的内容出现了,这个过程称之为repaint(重绘)[视觉上的感官] DOM元素的添加.修改(内容).删除(回流+重绘) 仅修改DOM元素的字体颜色(重绘,因为不需要调整布局

减少浏览器的reflow和repaint

1.避免在document上直接进行频繁的DOM操作,如果确实需要可以采用off-document的方式进行,具体的方法包括但不完全包括以下几种: (1). 先将元素从document中删除,完成修改后再把元素放回原来的位置 (2). 将元素的display设置为”none”,完成修改后再把display修改为原来的值 (3). 如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document 2.集中修改样式 (1). 尽可能少的修改元素style上的属

如何减少浏览器的reflow与repaint

1.避免在document上直接进行频繁的DOM操作,如果确实需要可以采用off-document的方式进行,具体的方法包括但不完全包括以下几种: (1). 先将元素从document中删除,完成修改后再把元素放回原来的位置 (2). 将元素的display设置为"none",完成修改后再把display修改为原来的值 (3). 如果需要创建多个DOM节点,可以使用DocumentFragment创建完后一次性的加入document 2.集中修改样式 (1). 尽可能少的修改元素sty

repaint和reflow

repaint(重绘) ,repaint发生更改时,元素的外观被改变,且在没有改变布局的情况下发生,如改变outline,visibility,background color,不会影响到dom结构渲染. reflow(渲染),与repaint区别就是他会影响到dom的结构渲染,同时他会触发repaint,他会改变他本身与所有父辈元素(祖先),这种开销是非常昂贵的,导致性能下降是必然的,页面元素越多效果越明显. 何时发生: 1. DOM元素的添加.修改(内容).删除( Reflow + Repa