回流(reflow)与重绘(repaint)

更新日期: 2021-07-30 阅读: 2.7k 标签: 渲染

浏览器的渲染过程

首先我们要了解浏览器的渲染过程:

  1.解析 html,生成 dom 树,解析 css,生成 CSSOM树

  2.将 DOM树 和 CSSOM树结合,生成渲染树(Render Tree)

  3.渲染树的每个元素包含的内容都是计算过的,它被称之为布局(layout)。浏览器使用一种流式处理的方法,只需要一次绘制操作就可以布局所有的元素

  4.将渲染树的各个节点绘制到屏幕上,这一步被称为绘制(painting)

即:解析html和css构建dom树和cssom树   ->   构建渲染树(render tree)  ->   布局render树(layout)  ->   绘制render树(painting)

 

回流(reflow)

回流又称重排,当浏览器发现布局(layout)发生了变化,这个时候就需要倒回去重新渲染,这个过程叫 回流(reflow)。回流几乎是无法避免的,因为只要用户进行了交互操作,就会发生页面的一部分重新渲染。

 

重绘(repaint)

重绘(repaint)则是当我们改变某个元素的背景色,文字颜色,边框颜色等不影响它周围或内部布局的属性是,屏幕的一部分要重画,但是元素的几何尺寸和位置没有发生改变。

需要注意的是 

  display:none 会触发回流(reflow),而

  visibility:hidden 属性表示隐藏元素,元素任然占据着布局空间,并没有改变布局和几何尺寸,所以只会触发 重绘(repaint)

 

何时引起回流(reflow)

现代浏览器会对回流做优化,它会等到足够数量的变化发生,再做一次批处理回流

  1.页面的第一次渲染(初始化)

  2.DOM树的变化(如:增删节点)

  3.Render树的变化(如:padding 改变)

  4.浏览器窗口的尺寸变化 resize

  5.fontsize的变化

  6.获取元素的某些属性

   浏览器为了获取正确的最新属性值也会提前触发回流,这些属性包括:

    offsetLest、 offsetTop、 offsetWidth、 offsetHeight、 scrollTop/Left/Width/Height、

    clientTop/Left/Width/Height、 调用了 getComputedStyle()。

 

何时引起重绘(repaint)

背景色、颜色的改变等会引起重绘(repaint)

 

回流和重绘的区别

当元素的位置或者几何尺寸发生改变时会触发回流,

而当背景色和颜色的改变会引起重绘,

注意:回流一定会发生重绘,而重绘不一定发生回流!

  

为了优化性能,我们需要减少回流、重绘的触发次数

  1.用 transform 做形变和位移可以减少回流

  2.避免组个修改节点样式,尽量一次性修改

  3.可以将需要多次修改的 DOM 元素设置 display:none ,操作完再显示(因为隐藏元素不在 render 树内,因此修改隐藏元素不会触发回流重绘)

  4.避免多次读取某些属性

  5.通过绝对位移将复杂的节点元素脱离文档流,形成新的 Render Layer,降低回流成本


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/10581

相关推荐

vue中数据更新变化,而页面视图未渲染的解决方案

在使用vue的时候,我们都知道它是双向数据绑定的,但是在使用不熟的情况下,经常会遇到:data中的数据变化了,但是并没有触发页面渲染。下面就整理一些出现这种情况的场景以及解决办法。

vue从后台获取数据赋值给data,如何渲染更细视图

如果从服务端返回的数据量较少,或者只有几个字段,可以用vue的set方法,如果数据量较大,请直接看第二种情况。官网API是这样介绍的:Vue.set(target,key,value)

React Native 使用 react-native-webview 渲染 HTML

在 App 中,渲染 HTML 是一个非常常见的功能,有可能是直接渲染 HTML 字符串或者是通过 URL 渲染远程 HTML页面。React Native 提供了一个 WebView 组件以供我们实现 HTML 的渲染。

vue 修改变量值无法渲染到页面

开发中碰到这么个问题,修改对象中的属性无法渲染页面。直接操作ccc变量就是没问题的。直接贴我的代码。解决方法一:注意,第二个参数是字符串类型,切记。

解决使用vue.js未渲染前代码显示问题

在使用vue的时候,偶然发现多次刷新或者网络加载缓慢的时候,会一瞬间出现设置的模板的情况。实在很影响美观,可以使用vue现成的指令来解决这个问题:v-cloak

服务端渲染和客户端渲染:CSR和SSR

现在的web网站都是非常讲究用户体验,一般都会采用服务端渲染加客户端渲染一起实现功能。服务端渲染有利于搜索引擎优化(SEO),利于被网页爬虫抓取数据,多见于电商网站商品信息获取等。客户端渲染不利于搜索引擎优化

在微信小程序中渲染html内容的实现

大部分Web应用的富文本内容都是以HTML字符串的形式存储的,通过HTML文档去展示HTML内容自然没有问题。但是,在微信小程序(下文简称为「小程序」)中,应当如何渲染这部分内容呢?

react 异步加载数据时的渲染问题

当数据需要异步加载时render获取不到数据可能会报一些错误,此时需要在render函数中加一个判断.行到render时,state对象的haveData为false, 所以此时页面展示 loading,当异步获取数据成功时

Web网页渲染的几种模式

本文主要内容来源于对上文的翻译,图也来源于此,加上了一点平时工作的理解,英语渣、翻译不是很准确,有条件的可以直接阅读上文链接。本文主要是自己在阅读时做的笔记,供自己以后查看。

细说 Vue 组件的服务器端渲染

现在,前后端分离与客户端渲染已经成为前端开发的主流模式,绝大部分的前端应用都适合用这种方式来开发,又特别是 React、Vue 等组件技术的发展,更是使这种方式深入人心。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!