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

重绘与重排如何使用

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含使用,如何,重排等相关知识,匿名希望在学习及工作中可以帮助到您
这次给大家带来重绘与重排如何使用,使用重绘与重排的注意事项有哪些,下面就是实战案例,一起来看一下。

浏览器加载页面原理

通常在文档初次加载时,浏览器引擎会解析HTML文档来构建DOM树,之后根据DOM元素的几何属性构建一棵用于渲染的树。渲染树的每个节点都有大小和边距等属性,类似于 盒子模型 (由于隐藏元素不需要显示,渲染树中并不包含DOM树中隐藏的元素)。当渲染树构建完成后,浏览器就可以将元素放置到正确的位置了,再根据渲染树节点的样式属性绘制出页面。由于浏览器的 流布局,对渲染树的计算通常只需要遍历一次就可以完成。但table及其内部元素除外,它可能需要多次计算才能确定好其在渲染树中节点的属性,通常要花3倍于同等元素的时间。这也是为什么我们要避免使用table做布局的一个原因。

重绘

重绘是一个元素 外观的改变 所触发的浏览器行为,例如改变vidibility、outline、背景色等属性。浏览器会根据元素的新属性重新绘制,使元素呈现新的外观。重绘不会带来重新布局,并不一定伴随重排。浏览器在进行重绘和重排的时候是要付出高昂的性能代价的。

重排

重排是更明显的一种改变,可以理解为渲染树需要重新计算。下面是常见的触发重排的操作:

  1. DOM元素的几何属性变化。

  2. DOM树的结构变化。

例如节点的增减、移动等.

获取某些属性。

当获取一些属性时,浏览器为取得正确的值也会触发重排。这样就使得浏览器的优化失效了。这些属性包括:offsetTop、offsetLeft、 offsetWidth、offsetHeight、scrollTop、scrollLeft、scrollWidth、scrollHeight、clientTop、clientLeft、clientWidth、clientHeight、getComputedStyle() (currentStyle in IE)。所以,在多次使用这些值时应进行缓存。

此外,改变元素的一些样式,调整浏览器窗口大小,滚动条出现等等也都将触发重排。

减少重排次数和重排影响范围

1、将多次改变样式属性的操作合并成一次操作。例如,

JS:
    var changep = document.getElementById(‘changep’);
    changep.style.color = ‘#093′;
    changep.style.background = ‘#eee';
    changep.style.height = ‘200px';
    可以合并为:
CSS:
    p.changep {
        background: #eee;
        color: #093;
        height: 200px;
    }
JS:
    document.getElementById(‘changep’).className = ‘changep';

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

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

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

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

相信看了本文案例你已经掌握了方法,更多精彩请关注微课江湖其它相关文章!

推荐阅读:

S5让分层屏幕适配

h5实现多图片预览上传及点击可拖拽控件

以上就是重绘与重排如何使用的详细内容,更多请关注微课江湖其它相关文章!

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

  • 使用phonegap进行提示操作的具体方法
  • HTML5标签使用方法详解
  • HTML5 video标签(播放器)学习笔记(一):使用入门
  • Javascript 高级手势使用介绍
  • HTML5的结构和语义(5):内嵌媒体
  • X/HTML5 和 XHTML2
  • HTML5 figure标签是什么意思?HTML5 figure标签的使用方法详解
  • html5 main标签是什么意思?html5 main标签作用的详细介绍
  • HTML5中的header标签是什么意思?HTML5中header标签具体使用方法你知道吗?
  • REM相对单位使用案例分享

相关文章

  • 2017-08-06HTML最新标准HTML5总结(必看)
  • 2017-08-06详解通过HTML5 Canvas实现图片的平移及旋转变化的方法
  • 2018-12-03html5 embed标签的loop属性是怎么用的?embed标签的属性总结!
  • 2018-12-03你不知道的CSS使用技巧
  • 2018-12-03详细介绍HTML5简易在线画图工具的实现案例
  • 2017-08-06HTML5是否真的可以取代Flash
  • 2018-12-03html5弹跳球示例代码_html5教程技巧
  • 2018-12-03html5使用canvas绘制太阳系效果
  • 2018-12-03基于html5实现的图片墙效果_html5教程技巧
  • 2017-08-06纯HTML5+CSS3制作生日蛋糕代码

文章分类

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

最近更新的内容

    • HTML5之SVG 2D入门4—笔画与填充
    • 移动端视网膜(Retina)屏幕下如何解决网页中1px显示问题?
    • zepto实现移动端无缝向上下滚动
    • html5文字阴影效果text-shadow使用示例
    • 解析HTML5中的新功能本地存储localStorage_html5教程技巧
    • 分享一个利用H5实现下拉顶部放大的实例代码
    • 推荐10款非常优秀的HTML5开发工具
    • HTML5 input元素类型:email及url介绍
    • HTML5应用-生日快乐动画的实现
    • H5移动端各种各样的列表的制作方法(一)

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

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