html中dom多会有影响吗,html-什么是重排和重绘?如何减少影响的范围

答:

重排:是引起DOM树重新计算的行为

重绘:一个元素外观的改变(如color)所触发的浏览器行为

减少:

分离读写操作;

样式集中改变;

使用absolute脱离文档流;

使用 display:none;

☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆

一个页面由两部分组成

DOM:描述该页面的结构

render:描述 DOM 节点 (nodes) 在页面上如何呈现

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

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

重绘不会带来重新布局,并不一定伴随重排

重排一定会引起浏览器的重绘

常见的触发重排的操作:

1.DOM树的结构变化,如节点的增减、移动

2.DOM元素的几何属性变化,如外边距、内边距、边框厚度、宽高、等几何属性)

3.窗口属性的获取和尺寸改变,如offsetTop、offsetLeft、 offsetWidth、offsetHeight、scrollTop、scrollLeft、scrollWidth、scrollHeight、 clientTop、clientLeft、clientWidth、clientHeight、getComputedStyle() (currentStyle in IE)

减少影响范围的具体方法:

1.分离读写操作,如

var curLeft=div.offsetLeft;

var curTop=div.offsetTop;

div.style.left=curLeft+1+'px';

div.style.top=curTop+1+'px';

2. 将多次改变样式属性的操作合并成一次操作

3.将需要多次重排的元素,position属性设为absolute或fixed,这样此元素就脱离了文档流,它的变化不会影响到其他元素。例如有动画效果的元素就最好设置为绝对定位。

4. 由于display属性为none的元素不在渲染树中,对隐藏的元素操作不会引发其他元素的重排。如果要对一个元素进行复杂的操作时,可以先隐藏它,操作完成后再显示。这样只在隐藏和显示时触发2次重排。

5.在内存中多次操作节点,完成后再添加到文档中去。例如要异步获取表格数据,渲染到页面。可以先取得数据后在内存中构建整个表格的html片段,再一次性添加到文档中去,而不是循环添加每一行。

6. 在需要经常取那些引起浏览器重排的属性值时,要缓存到变量,如窗口的offsetTop、offsetLeft事先缓存

本文来源于网络:查看 >https://blog.csdn.net/wangjiaohome/article/details/80499589

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值