• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 浏览器的重绘repaints与重排reflows深入分析

浏览器的重绘repaints与重排reflows深入分析

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含浏览器,重绘repaints,重排reflows等相关知识,佚名 希望在学习及工作中可以帮助到您
在项目的交互或视觉评审中,前端同学常常会对一些交互效果质疑,提出这样做不好那样做不好。主要原因是这些效果通常会产生一系列的浏览器重绘和重排,需要付出高昂的性能代价。那么,什么是浏览器的重绘和重排呢?二者何时发生以及如何权衡?如何在具体的开发过程中将重绘和重排引发的性能问题考虑进去?本文期待可以部分解释以上三个问题。
  浏览器从下载文档到显示页面的过程是个复杂的过程,这里包含了重绘和重排。各家浏览器引擎的工作原理略有差别,但也有一定规则。简单讲,通常在文档初次加载时,浏览器引擎会解析HTML文档来构建DOM树,之后根据DOM元素的几何属性构建一棵用于渲染的树。渲染树的每个节点都有大小和边距等属性,类似于盒子模型(由于隐藏元素不需要显示,渲染树中并不包含DOM树中隐藏的元素)。当渲染树构建完成后,浏览器就可以将元素放置到正确的位置了,再根据渲染树节点的样式属性绘制出页面。由于浏览器的流布局,对渲染树的计算通常只需要遍历一次就可以完成。但table及其内部元素除外,它可能需要多次计算才能确定好其在渲染树中节点的属性,通常要花3倍于同等元素的时间。这也是为什么我们要避免使用table做布局的一个原因。
  重绘是一个元素外观的改变所触发的浏览器行为,例如改变vidibility、outline、背景色等属性。浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。重绘不会带来重新布局,并不一定伴随重排。
  重排是更明显的一种改变,可以理解为渲染树需要重新计算。下面是常见的触发重排的操作:
1. DOM元素的几何属性变化
  当DOM元素的几何属性变化时,渲染树中的相关节点就会失效,浏览器会根据DOM元素的变化重建构建渲染树中失效的节点。之后,会根据新的渲染树重新绘制这部分页面。而且,当前元素的重排也许会带来相关元素的重排。例如,容器节点的渲染树改变时,会触发子节点的重新计算,也会触发其后续兄弟节点的重排,祖先节点需要重新计算子节点的尺寸也会产生重排。最后,每个元素都将发生重绘。可见,重排一定会引起浏览器的重绘,一个元素的重排通常会带来一系列的反应,甚至触发整个文档的重排和重绘,性能代价是高昂的。
2.DOM树的结构变化
  当DOM树的结构变化时,例如节点的增减、移动等,也会触发重排。浏览器引擎布局的过程,类似于树的前序遍历,是一个从上到下从左到右的过程。通常在这个过程中,当前元素不会再影响其前面已经遍历过的元素。所以,如果在body最前面插入一个元素,会导致整个文档的重新渲染,而在其后插入一个元素,则不会影响到前面的元素。
3.获取某些属性
  浏览器引擎可能会针对重排做了优化。比如Opera,它会等到有足够数量的变化发生,或者等到一定的时间,或者等一个线程结束,再一起处理,这样就只发生一次重排。但除了渲染树的直接变化,当获取一些属性时,浏览器为取得正确的值也会触发重排。这样就使得浏览器的优化失效了。这些属性包括:offsetTop、offsetLeft、 offsetWidth、offsetHeight、scrollTop、scrollLeft、scrollWidth、scrollHeight、clientTop、clientLeft、clientWidth、clientHeight、getComputedStyle() (currentStyle in IE)。所以,在多次使用这些值时应进行缓存。
  此外,改变元素的一些样式,调整浏览器窗口大小等等也都将触发重排。
  开发中,比较好的实践是尽量减少重排次数和缩小重排的影响范围。例如:
1. 将多次改变样式属性的操作合并成一次操作。例如,
JS:

在最近几次面试中比较常问的一个问题:在前端如何实现一个表格的排序。如果应聘者的方案中考虑到了如何减少重绘和重排的影响,将是使人满意的方案。

您可能想查找下面的文章:

  • 针对IE浏览器的兼容问题小结
  • 避免不必要的浏览器兼容性问题的5个技巧
  • 详解CSS3浏览器兼容
  • 解决360双核浏览器兼容模式的页面显示问题
  • 兼容主流浏览器的CSS透明代码(必看篇)
  • 浅谈浏览器的兼容性(必看篇)
  • 如何判断PC端浏览器内核
  • 浏览器hack总结 详细的浏览器兼容性的快速解决方法
  • 网站变灰色兼容代码 包括图片 支持所有浏览器
  • 一句话解决傻傻的多核浏览器切换

相关文章

  • 2017-08-06css3media响应式布局实例
  • 2017-08-06CSS图片翻转动画技术详解(IE也实现了)
  • 2017-08-06强制显示、隐藏(IE\Mozilla)浏览器的滚动条实现代码
  • 2017-08-06css设置各种中文字体如雅黑、黑体、宋体、楷体等等
  • 2017-08-06list-style-image无法准确定位通过(li的背景模拟或相对定位)解决
  • 2017-08-06跨浏览器的inline-block声明上承诺了很多提供的却很少
  • 2017-08-06使用CSS Grid布局实现网格的流动
  • 2017-08-06使用CSS实现小三角形效果【附实例】
  • 2017-08-06一个div在浏览器水平居中的实现方法
  • 2017-08-06CSS如何实现表头冻结效果

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • css三级下拉菜单实现方法分享
    • css中用list-style-type指定列表(lists)前面符号
    • 级联样式文件共通样式整理
    • 仿Word自动套用格式使用CSS设置表格样式实例
    • 权重和层叠规则决定了CSS样式优先级
    • 纯CSS制作的响应式折叠菜单分享
    • CSS如何让一个按钮居中应该怎么做
    • 使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
    • css移动端实现与pc端一样的:acitve效果
    • CSS实现鼠标上移图标旋转效果

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有