首页 > 其他分享 >页面的重绘(repaint)与重排(reflow)

页面的重绘(repaint)与重排(reflow)

时间:2023-02-13 11:25:59浏览次数:42  
标签:repaint 浏览器 reflow 重绘 改变 重排 节点

1 重绘(repaint):

屏幕的一部分要重绘。渲染树节点发生改变,但不影响该节点在页面当中的空间位置及大小。譬如某个div标签节点的背景颜色、字体颜色等等发生改变,但是该div标签节点的宽、高、内外边距并不发生变化,此时触发浏览器重绘(repaint)。

 

2 重排(reflow):

也有称回流,当渲染树节点发生改变,影响了节点的几何属性(如宽、高、内边距、外边距、或是float、position、display:none;等等),导致节点位置发生变化,此时触发浏览器重排(reflow),需要重新生成渲染树。譬如JS为某个p标签节点添加新的样式:"display:none;"。导致该p标签被隐藏起来,该p标签之后的所有节点位置都会发生改变。此时浏览器需要重新生成渲染树,重新布局,即重排(reflow)。

 

注意:重排必将引起重绘,而重绘不一定会引起重排。

 

何时回引起重排?

 

当页面布局和几何属性改变时就需要重排。下述情况会发生浏览器重排:

 

1、添加或者删除可见的DOM元素;

 

2、元素位置改变——display、float、position、overflow等等;

 

3、元素尺寸改变——边距、填充、边框、宽度和高度

 

4、内容改变——比如文本改变或者图片大小改变而引起的计算值宽度和高度改变;

 

5、页面渲染初始化;

 

6、浏览器窗口尺寸改变——resize事件发生时;

3 如何减少和避免重排

Reflow 的成本比 Repaint 的成本高得多的多。一个节点的 Reflow 很有可能导致子节点,甚至父节点以及兄弟节点的 Reflow 。在一些高性能的电脑上也许还没什么,但是如果 Reflow 发生在手机上,那么这个过程是延慢加载和耗电的。----浏览器的渲染原理简介

  1. 直接改变className,如果动态改变样式,则使用cssText(考虑没有优化的浏览器);
  2. 让要操作的元素进行”离线处理”,处理完后一起更新;

a) 使用DocumentFragment进行缓存操作,引发一次回流和重绘;

b) 使用display:none技术,只引发两次回流和重绘;

c) 使用cloneNode(true or false) 和 replaceChild 技术,引发一次回流和重绘;

3.不要经常访问会引起浏览器flush队列的属性,如果你确实要访问,利用缓存;

4.让元素脱离动画流,减少回流的Render Tree的规模;

标签:repaint,浏览器,reflow,重绘,改变,重排,节点
From: https://www.cnblogs.com/zhaofen/p/17115653.html

相关文章

  • 3DUI改变字体大小后框没有自动缩小需要重绘吗?不需要
    设置手工重绘以及调用重绘解决不了问题UJK)NYV`M`%HOM4OQ4D7HI0.png最后我调整ui结构外层套一个包裹就行了image.png......
  • 深入了解重绘和回流
    重绘(repainting):元素样式发生改变,但宽高、大小、位置等不变;如:color、background-color属性回流(layout):元素的大小或者位置发生了变化(当页面布局和几何信息发生变化的时候),触......
  • 页面重排和重绘问题
    页面重排(reflow)是指浏览器重新计算页面的渲染布局,通常是由于元素的尺寸、位置或者视口尺寸发生了变化导致的。重排会影响页面的性能,应尽量避免。页面重绘(repaint)是指浏览......
  • 浏览器 - 重绘(repaint)重排(reflow)
    浏览器-重绘(repaint)重排(reflow)网页生成过程:HTML被HTML解析器解析成DOM树css则被css解析器解析成CSSOM树结合DOM树和CSSOM树,生成一棵渲染树(RenderTree)生成......
  • qwtPlot实现清屏重绘
    #include"readflowpoint.h"#include"qfile.h"#include"qmessagebox.h"#include"qwt_legend.h"#include"qwt_plot_grid.h"#include"qwt_scale_draw.h"#include......
  • 回流(Reflow)与重绘(Repaint)
    哪些实际操作会导致回流与重绘最“贵”的操作:改变DOM元素的几何属性这个改变几乎可以说是“牵一发动全身”——当一个DOM元素的几何属性发生变化时,所有和它相关的节......
  • 重绘和回流
    为什么总说jQuery操作DOM耗费资源,那他消耗了个什么资源,他是怎么消耗的呢???咳咳,其实很简单的一玩意......
  • 回流与重绘
    前言在HTML中,每个元素都可以理解成一个盒子,在浏览器解析过程中,会涉及到回流与重绘:回流:布局引擎会根据各种样式计算每个盒子在页面上的大小与位置重绘:当计算好盒模型的位......
  • RowPrePaint 事件死循环(不停的刷新)问题 解决
    privatevoiddgv_RowPrePaint(objectsender,DataGridViewRowPrePaintEventArgse){if(infos[e.RowIndex].HaveDetails=="不存在")//此条......
  • 什么是重排和重绘
    当浏览器下载完页面所需元素(html标记,css层叠样式表,javascript,图片)之后,会生成两个东西:Dom树和渲染树。Dom树Dom树,主要是用来表示页面的Dom结构。渲染树渲染树主要是用来表示......