首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

精读《web reflow

但也不尽然,因为浏览器会自动合并更改,在达到某个数量或时间后,会合并为一次 reflow,而 reflow 是渲染页面的重要一步,打开浏览器就一定会至少 reflow 一次,所以我们不可能避免 reflow...那为什么要注意 reflow 导致的性能问题呢?...这是因为某些代码可能导致浏览器优化失效,即明明能合并 reflow 时没有合并,这一般出现在我们用 js API 访问某个元素尺寸时,为了保证拿到的是精确值,不得不提前触发一次 reflow,即便写在...当然也不是每次访问元素位置都会触发 reflow,在浏览器触发 reflow 后,所有已有元素位置都会记录快照,只要不再触发位置等变化,第二次开始访问位置就不会触发 reflow,关于这一点会在后面详细展开...(源码) 精读 What forces layout / reflow 下面引用了几篇关于 reflow 的相关文章,笔者挑几个重要的总结一下。

69910

性能优化之reflow和repaint

本文主要介绍一下什么是reflow,repaint, 怎样避免它们造成的不良影响, 怎么通过工具查看分析它们.  ...重新渲染就行重新生成布局和绘制(也就是重复进行上面的第4,5步)重新生成布局的过程就是reflow(回流,重排),重新绘制就叫做reflow(重绘)。...三: 什么时候触发reflow和repaint 注: repaint不一定需要reflow,例如:改变某元素的颜色,只会触发repaint,不会触发reflow。...但是reflow一定会导致repaint,因为布局改变了,就一定需要重新绘制。 Reflow 的成本比 Repaint 的成本高很多。...DOM Tree里的每个节点都会有reflow方法,一个结点的reflow可能导致其子结点,甚至父点以及同级结点的 reflow。在PC端或许还没什么,但是在手机上,还是比较耗性能和耗电的。

1.4K80
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    前端页面优化,减少 reflow 的方法

    reflow也就是 重排或者回流 由DOM或者布局的变动而触发。 如你改变了一个div的位置,或者是改变了这个div的width, height, position 或者布局类的样式。...等操作完成在会后,再将它display:block,这样只会触发2次的reflow。 利用innerHTML 当然上述的写法也可以利用innerHTML进行修改。...text fragment.appendChild(li) }) parentNode.appendChild(fragment) 复制代码 如果不使用DocumentFragment的话,会造成4次reflow...,随着需要修改的dom次数变多,还会造成更多次的reflow,但是通过fragment,只需要一次就够了。...CSS 层面的优化 我们上面说了,不只是DOM tree的改变会触发reflow,CSSOM的改变同样会触发。 这里我们可以用替代的CSS属性替代会造成reflow的属性。

    25110

    什么是回流与重绘 (Reflow & Repaint)

    Contents 1 写在前面 2 回流(Reflow) 3 重绘(Repaint) 4 影响 5 避免重绘与回流 6 总结 写在前面 在讨论今天的主角之前,我们要先了解一下浏览器的渲染机制。...生成CSSOM 规则树 将 DOM 树与 CSSOM 规则树合并在一起生成渲染树Render Tree 根据渲染树遍历拿到每个节点开始布局,计算每个节点的位置大小信息 将渲染树每个节点绘制到屏幕 回流(Reflow...elem.scrollLeft, elem.scrollTop 其他 上述主要是我们经常使用的一些API,其他还有一个api已经有热心网友帮我们整理出来了 我们可以看一下 What forces layout / reflow...我们抽离中间或者底部的一个积木块,我们的积木会重新找到重心并且稳固下来,我们把这个过程称之为回流 我们在某个积木上涂上颜色,这并不会造成整个积木的稳定,我们把这个过程叫做重绘 或者说,我们简单理解会引起元素位置变化的就会reflow...,会引起位置变化的,只是在以前的位置进行改变背景颜色等,只会repaint 本文首发于什么是回流与重绘 (Reflow & Repaint)

    87110

    reflow和repaint(摘录自张鑫旭的翻译)

    注意:这里我限定了自己只能讨论CSS对回流的影响,如果您是一位JavaScript程序员,我是推荐您读一下我的reflow链接(zxx: 原作者收藏标记的一些关于reflow的一些文章或页面链接),有一些非常好的东西...另一篇有关reflow的翻译 回流(reflow)这个名词指的是网络浏览器为了重新渲染部分或全部的文档而重新计算文档中元素的位置和几何结构的过程。...因为回流(reflow)在浏览器中属于一种用户主导的模块化操作,所以知道如何去改进回流(reflow)时间以及知道各种文档属性(DOM节点深度,css的渲染效率,各种各样的样式改变)对回流(reflow...有大量的用户行为以及潜在的DHTML改变会触发回流(reflow)。...从上边的表格我们可以清晰的看到并不是所有JavaScript改变的样式都会在浏览器中产生回流(reflow),所花费的回流(reflow)时间也是多样的。

    1.1K40

    浏览器渲染原理

    Reflow ——意味着元件的几何尺寸变了,我们需要重新验证并计算Render Tree。是Render Tree的一部分或全部发生了变化。这就是Reflow,或是Layout。...Reflow的成本比Repaint的成本高得多的多。DOM Tree里的每个结点都会有reflow方法,一个结点的reflow很有可能导致子结点,甚至父点以及同级结点的reflow。...因为滚屏也有可能会造成reflow。 基本上来说,reflow有如下的几个原因: Initial。网页初始化的时候。 Incremental。一些Javascript在操作DOM Tree时。...一般来说,浏览器会把这样的操作积攒一批,然后做一次reflow,这又叫异步reflow或增量异步reflow。但是有些情况浏览器是不会这么做的,比如:resize窗口,改变了页面默认的字体,等。...对于这些操作,浏览器会马上进行reflow

    2.7K31

    浏览器渲染流程

    Reflow——意味着元件的几何尺寸变了,我们需要重新验证并计算Render Tree。是Render Tree的一部分或全部发生了变化。这就是Reflow,或是Layout。...Reflow的成本比Repaint的成本高得多的多。DOM Tree里的每个结点都会有reflow方法,一个结点的reflow很有可能导致子结点,甚至父点以及同级结点的reflow。...因为滚屏也有可能会造成reflow。 基本上来说,reflow有如下的几个原因: Initial。网页初始化的时候。 Incremental。一些Javascript在操作DOM Tree时。...一般来说,浏览器会把这样的操作积攒一批,然后做一次reflow,这又叫异步reflow或增量异步reflow。但是有些情况浏览器是不会这么做的,比如:resize窗口,改变了页面默认的字体,等。...对于这些操作,浏览器会马上进行reflow

    48330

    浏览器渲染原理

    Reflow ——意味着元件的几何尺寸变了,我们需要重新验证并计算Render Tree。是Render Tree的一部分或全部发生了变化。这就是Reflow,或是Layout。...Reflow的成本比Repaint的成本高得多的多。DOM Tree里的每个结点都会有reflow方法,一个结点的reflow很有可能导致子结点,甚至父点以及同级结点的reflow。...因为滚屏也有可能会造成reflow。 基本上来说,reflow有如下的几个原因: Initial。网页初始化的时候。 Incremental。一些Javascript在操作DOM Tree时。...一般来说,浏览器会把这样的操作积攒一批,然后做一次reflow,这又叫异步reflow或增量异步reflow。但是有些情况浏览器是不会这么做的,比如:resize窗口,改变了页面默认的字体,等。...对于这些操作,浏览器会马上进行reflow

    49020

    浏览器渲染原理

    Reflow ——意味着元件的几何尺寸变了,我们需要重新验证并计算Render Tree。是Render Tree的一部分或全部发生了变化。这就是Reflow,或是Layout。...Reflow的成本比Repaint的成本高得多的多。DOM Tree里的每个结点都会有reflow方法,一个结点的reflow很有可能导致子结点,甚至父点以及同级结点的reflow。...因为滚屏也有可能会造成reflow。 基本上来说,reflow有如下的几个原因: Initial。网页初始化的时候。 Incremental。一些Javascript在操作DOM Tree时。...一般来说,浏览器会把这样的操作积攒一批,然后做一次reflow,这又叫异步reflow或增量异步reflow。但是有些情况浏览器是不会这么做的,比如:resize窗口,改变了页面默认的字体,等。...对于这些操作,浏览器会马上进行reflow

    1.1K00

    浏览器渲染原理解析建议收藏

    那是因为浏览器要花时间、花精力去渲染,尤其是当它发现某个部分发生了点变化影响了布局,需要倒回去重新渲染,内行称这个回退的过程叫reflow。...reflow问题是可以优化的,我们可以尽量减少不必要的reflow。比如开头的例子中的图片载入问题,这其实就是一个可以避免的reflow——给图片设置宽度和高度就可以了。...另外,有个和reflow看上去差不多的术语:repaint,中文叫重绘。如果只是改变某个元素的背景色、文 字颜色、边框颜色等等不影响它周围或内部布局的属性,将只会引起浏览器repaint。...repaint的速度明显快于 reflow(在IE下需要换一下说法,reflow要比repaint 更缓慢)。

    27820

    HTML中的重绘与回流

    其中的Layout就是布局,页面第一次被加载时或是当Render Tree改变需要重新布局时,就产生了回流(reflow)/重排(relayout)。...Tree中的一部分(或全部)的node(节点)因为元素的规模尺寸、布局方式、显示隐藏等改变,浏览器为了重新渲染部分或整个页面,重新计算页面元素位置和几何结构的过程,也就是重新构造渲染树 ,这个过程叫做回流(reflow...回流/重排(Reflow):当渲染树的一部分必须更新并且节点的尺寸发生了变化,浏览器会使渲染树中受到影响的部分失效,并重新构造渲染树。...比如改变某个元素的背景色、文字颜色、边框颜色等等 影响回流(reflow)/重排(relayout)的因素 影响重绘(replaint)的因素 元素的布局和几何属性改变时就会触发reflow。...(3)为动画的 HTML 元件使用 fixed 或 absoult 的 position,那么修改他们的 CSS 是不会 reflow 的。 (4)千万不要使用 table 布局。

    1.4K20
    领券