首页 > 其他分享 >chrome对页面重绘和回流以及优化进行优化

chrome对页面重绘和回流以及优化进行优化

时间:2023-04-09 17:22:30浏览次数:56  
标签:DOM chrome 元素 回流 属性 优化 重绘 页面

页面的绘制时间(paint time)是每一个前端开发都需要关注的的重要指标,它决定了你的页面流畅程度。而如何去观察页面的绘制时间,找到性能瓶颈,可以借助Chrome的开发者工具。

 

 

回流与重绘

1. 当render tree中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构建。这就称为回流(reflow)。每个页面至少需要一次回流,就是在页面第一次加载的时候。在回流的时候,浏览器会使渲染树中受到影响的部分失效,并重新构造这部分渲染树,完成回流后,浏览器会重新绘制受影响的部分到屏幕中,该过程成为重绘。

2. 当render tree中的一些元素需要更新属性,而这些属性只是影响元素的外观,风格,而不会影响布局的,比如background-color。则就叫称为重绘。

注意:回流必将引起重绘,而重绘不一定会引起回流。

回流何时发生:

当页面布局和几何属性改变时就需要回流。下述情况会发生浏览器回流:

  1. 页面渲染初始化;

  2. 调整窗口大小(Resizing the window),浏览器窗口尺寸改变——resize事件发生时

  3. 增加或者移除样式表(Adding or removing a stylesheet)

  4. 元素位置改变、元素尺寸改变——width/height/padding/border/margin

  5. 内容改变——比如文本改变或者图片大小改变而引起的计算值宽度和高度改变;

  6. 改变字体(Changing the font)

  7. 激活 CSS 伪类,比如 :hover (IE 中为兄弟结点伪类的激活)(Activation of CSS pseudo classes such as :hover (in IE the activation of the pseudo class of a sibling))

  8. 操作 class 属性(Manipulating the class attribute)

  9. 脚本操作 DOM(A script manipulating the DOM),添加或者删除可见的DOM元素;

  10. 计算 offsetWidth 和 offsetHeight 属性(Calculating offsetWidth and offsetHeight)

  11. 设置 style 属性的值 (Setting a property of the style attribute)

这么多,分类整理记忆下:

js请求以下style信息时,触发回流(浏览器会立刻清空队列:)

  • clientWidth、clientHeight、clientTop、clientLeft

  • offsetWidth、offsetHeight、offsetTop、offsetLeft

  • scrollWidth、scrollHeight、scrollTop、scrollLeft

  • width、height

  • getComputedStyle()

  • getBoundingClientRect()

css中如下属性,触发回流

  • width/height/padding/border/margin

  • font/line-height/font-weight/

  • postion/display/float/clear/

js操作DOM,修改class属性,修改样式表,修改文档内容,修改元素计算样式

让我们看看下面的代码是如何影响回流和重绘的:

ar s = document.body.style;
s.padding = "2px"; // 回流+重绘
s.border = "1px solid red"; // 再一次 回流+重绘
s.color = "blue"; // 再一次重绘
s.backgroundColor = "#ccc"; // 再一次 重绘
s.fontSize = "14px"; // 再一次 回流+重绘
// 添加node,再一次 回流+重绘
document.body.appendChild(document.createTextNode('abc!'));

然而这些都是意淫:那么

怎么监控重绘回流

chorme 按下:f12,然后按下 esc……

blob.png

但是,我按了没有 readering

那是你没有勾选啊,console 旁边有三点是不是,点击,然后勾选,rendering……

以上5个选项的意思如下:

  1. Show paint rectangles 显示绘制矩形

  2. Show composited layer borders 显示层的组合边界(注:蓝色的栅格表示的是分块)

  3. Show FPS meter 显示FPS帧频

  4. Enable continuous page repainting 开启持续绘制模式 并 检测页面绘制时间

  5. Show potential scroll bottlenecks 显示潜在的滚动瓶颈。

 

优化重绘回流

CSS

 

  • 避免使用table布局。

  • 尽可能在DOM树的最末端改变class。

  • 避免设置多层内联样式。

  • 将动画效果应用到position属性为absolute或fixed的元素上。

  • 避免使用CSS表达式(例如:calc())。

 

JavaScript

 

  • 避免频繁操作样式,最好一次性重写style属性,或者将样式列表定义为class并一次性更改class属性。

  • 避免频繁操作DOM,创建一个documentFragment,在它上面应用所有DOM操作,最后再把它添加到文档中。

  • 也可以先为元素设置display: none,操作结束后再把它显示出来。因为在display属性为none的元素上进行的DOM操作不会引发回流和重绘。

  • 避免频繁读取会引发回流/重绘的属性,如果确实需要多次使用,就用一个变量缓存起来。

  • 对具有复杂动画的元素使用绝对定位,使它脱离文档流,否则会引起父元素及后续元素频繁回流。基本原则就是,把动画元素用position:absolute踢出文档流,这样R&R就限制在了absolute元素的子节点。告诉浏览器,我这块结构跟其他的单独渲染,不要搅和全页面了。

 

参看文章:

回流与重绘:CSS性能让JavaScript变慢?

 

 

 


转载本站文章《chrome对页面重绘和回流以及优化进行优化》,
请注明出处:https://www.zhoulujun.cn/html/webfront/browser/webkit/2016_0506_7820.html

标签:DOM,chrome,元素,回流,属性,优化,重绘,页面
From: https://www.cnblogs.com/zhoulujun/p/17300621.html

相关文章

  • js异步——浅谈Chrome浏览器架构
    前言在讲述事件循环和消息队列之前,需要了解JS的单线程执行机制,JS的执行是从上到下依次执行的,这些便是同步任务,而异步操作类似于系统中断,即当前进程外部的实体(主线程之外的、宿主环境提供的、特殊的线程,如IO线程(HTTP请求)和定时器线程等)可以触发代码执行,然后在异步任务完毕后,执......
  • Chrome扩展开发的简介与实战(1)
    tags:学习前言本课的目的使大家学会最基础的Chrome扩展开发理念以实战为主,概念为辅本来我是想按部就班,条条框框的一步一步从概念,特点,等等讲起。左思右想觉得这样未免太过枯燥,如果大家失去了兴趣,讲得再有条理也是枉然。所以还是结合实战,能做出东西才是王道。上课形式......
  • Android遇到内存泄漏和性能优化,需要采取以下措施
    内存泄漏:a.使用内存分析工具,如AndroidStudio的MemoryProfiler或LeakCanary,找出内存泄漏的位置,并修复代码。b.避免在Activity或Fragment中使用静态变量或单例模式,因为它们可能会持有对Activity或Fragment的引用,并导致内存泄漏。c.及时释放不再使用的资源,如关闭文件、释放......
  • 10.大牛是怎么思考设计MySQL优化方案的?
    https://www.cnblogs.com/keme/p/10300154.htmlhttps://www.cnblogs.com/keme/p/10472283.html ......
  • 前端性能优化-gzip压缩
    提纲:GZIP是什么如何启用gzip什么时候应该启用gzip1、gzip压缩是什么gzip是一种文件压缩格式,它可以将文件压缩为较小的大小,以便更快地在网络上传输或存储在磁盘上。gzip压缩算法适用于文本类型的数据,通常用于压缩Web服务器上的静态资源文件,例如HTML,CSS,JavaScript文件和......
  • 基于蜘蛛黄蜂优化器 (SWO)求解单目标优化问题附matlab代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • 2-程序性能优化
    1、C++性能测试工具GPROFhttp://sourceware.org/binutils/docs-2.17/gprof/index.htmlhttp://blog.csdn.net/stanjiang2010/article/details/5655143GPROF是GCC自带的性能测试工具,可以统计出各个函数的调用次数、时间、以及函数调用图。使用GRPOF分为三个步骤(1)编译时候打开......
  • 移动端技术:如何优化网站以适应不同设备?
    ​ 随着移动设备的普及,越来越多的用户使用手机和平板电脑来访问网站。因此,网站的移动端优化变得越来越重要。本文将介绍如何优化网站以适应不同设备。一、响应式设计响应式设计是一种能够自适应不同设备的网站设计方式。它可以根据用户的设备大小和屏幕分辨率来自动调整网站的......
  • Chrome浏览器不同版本兼容性的验证方法
    Chrome浏览器不同版本兼容性的验证方法背景上周客户现场有出现使用国产信创设备上面的奇安信浏览器出现兼容性的问题.开发认为是测试不全面导致.认为测试应该必须测试过特定浏览器才可以进行说明.最开始国产设备上面仅能够支持firefox52.3ESR的版本当时在进行银河麒麟和UO......
  • Android性能优化
     在如今的移动互联网时代,移动设备的使用越来越普遍,而Android作为一个开放、免费的操作系统,更是占据了全球智能手机市场的绝大部分份额。然而,Android设备的性能问题也是使用者非常关心的问题,因此,Android性能优化也是开发者不得不重视的问题。Android应用的性能问题主要体现......