zoukankan      html  css  js  c++  java
  • 重排与重绘

    当DOM的变化影响了元素的几何属性(宽或高),浏览器需要重新计算元素的几何属性,同样其他元素的几何属性和位置也会因此受到影响。浏览器会使渲染树中受到影响的部分失效,并重新构造渲染树。这个过程称为重排。完成重排后,浏览器会重新绘制受影响的部分到屏幕,该过程称为重绘

    重绘是一个元素外观的改变所触发的浏览器行为,例如改变visibility、outline、背景色等属性。浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。重绘不会带来重新布局,并不一定伴随重排。

    重排是更明显的一种改变,可以理解为渲染树需要重新计算。

    重排会在哪些情况下发生?

    1. 添加或者删除可见的DOM元素
    2. 元素位置改变
    3. 元素尺寸改变
    4. 元素内容改变(例如:一个文本被另一个不同尺寸的图片替代)
    5. 页面渲染初始化(这个无法避免)
    6. 浏览器窗口尺寸改变

    重排和重绘是DOM编程中耗能的主要原因之一,平时涉及DOM编程时可以参考以下几点:

    1. 尽量不要在布局信息改变时做查询(会导致渲染队列强制刷新)
    2. 同一个DOM的多个属性改变可以写在一起(减少DOM访问,同时把强制渲染队列刷新的风险降为0)
    3. 如果要批量添加DOM,可以先让元素脱离文档流,操作完后再带入文档流,这样只会触发一次重排(fragment元素的应用)
    4. 将需要多次重排的元素,position属性设为absolute或fixed,这样此元素就脱离了文档流,它的变化不会影响到其他元素。例如有动画效果的元素就最好设置为绝对定位。
    5. 将多次改变样式属性的操作合并成一次操作
    6. 在内存中多次操作节点,完成后再添加到文档中去。例如要异步获取表格数据,渲染到页面。可以先取得数据后在内存中构建整个表格的html片段,再一次性添加到文档中去,而不是循环添加每一行。

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

    8. 在需要经常获取那些引起浏览器重排的属性值时,要缓存到变量。

    9. 直接改变className,如果动态改变样式,则使用cssText(考虑没有优化的浏览器)
  • 相关阅读:
    oracle-PL/SQL1
    ROS之Gazebo
    ROS之urdf 2
    ROS之urdf 1
    ROS 面部识别
    ROS x Arduino
    STM32F0的低功耗模式
    项目进度
    C++函数返回为引用
    STM32F0的多路ADC 无DMA
  • 原文地址:https://www.cnblogs.com/bagexiaowenti/p/8025619.html
Copyright © 2011-2022 走看看