HTML5+CSS3-基础05-重排&重绘

重排(Relayout/Reflow)

重排也叫回流,所谓重排,实际上是根据渲染树中每个渲染对象的信息,计算出各自渲染对象的几何信息(DOM对象的位置和尺寸大小),并将其安置在界面中的正确位置。由于浏览器渲染界面是基于流式布局模型的,也就是某一个DOM节点信息更改了,就需要对DOM结构进行重新计算,重新布局界面,

引起重排的操作有:

1.页面首次渲染。

2.浏览器窗口大小发生改变。

3.元素尺寸或位置发生改变。

4.元素内容变化(文字数量或图片大小等等)。

5.元素字体大小变化。

6.添加或者删除可见的DOM元素。

7.激活CSS伪类(例如::hover)。

8.设置style属性

9.查询某些属性或调用某些方法。
在这里插入图片描述

重绘(Repainting)

重绘,就是当页面中元素样式的改变并不影响它在文档流中的位置时,例如更改了字体颜色,浏览器会将新样式赋予给元素并重新绘制的过程称。
在这里插入图片描述

性能优化

1. 减少DOM操作

(1)最小化DOM访问次数,尽量缓存访问DOM的样式信息,避免过度触发回流。
(2)如果在一个局部方法中需要多次访问同一个dom,则先暂存它的引用。

2. 采用更优的API

(1)用querySelectorAll()替代getElementByXX()。

(2)用事件委托来减少事件处理器的数量。

4. 减少重排

(1)避免设置大量的style属性,因为通过设置style属性改变结点样式的话,每一次设置都会触发一次reflow,所以最好是使用class属性
(2)实现元素的动画,它的position属性,最好是设为absoulte或fixed,这样不会影响其他元素的布局

5. css动画

(1)少用css表达式
(2)减少通过JavaScript代码修改元素样式,尽量使用修改class名方式操作样式或动画;

内容仅供学习参考,若有错误欢迎大家指正----WUCASE

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值