扫码关注公众号

前端浏览器考点之页面渲染
11-06
257观看
01

浏览器的渲染机制可以分为几步?

第一步:解析html,构建DOM树第二步:解析CSS,生成CSSOM树第三步:合并dom树和css规则树,生成render渲染树第四步:根据render渲染树进行布局第五步:调用GPU对渲染树进行绘制,合成图层,显示在屏幕上其中第四步和第五步合起来,就是我们常常说的浏览器渲染,并且第四步和第五步是浏览器渲染最耗时的部分(主要优化点)

来自:浏览器、网络相关-浏览器页面渲染
02

简单介绍浏览器渲染的五个阶段

第一步:解析html标签,构建DOM树在这个阶段,引擎开始解析html,解析出来的结果会成为一棵dom树(包含全节点,包括隐藏的节点和<head>标签)dom树构建完成以后主要作为下阶段渲染树状图的输入,并且成为网页和脚本的交互界面。(最常用的就是getElementById等等)当解析器到达script标签的时候,发生下面四件事情html解析器停止解析如果是外部脚本,就从外部网络获取脚本代码将控制权交给js引擎,执行js代码恢复html解析器的控制权结论:由于<script>标签是阻塞解析的,将脚本放在网页尾部会加速代码渲染。第二步:解析CSS标签,构建CSSOM树js会阻塞解析,因为它会修改文档(document)。css不会修改文档的结构,如果这样的话,似乎看起来css样式不会阻塞浏览器html解析。但是事实上css样式表是阻塞的。阻塞是指当cssom树建立好之后才会进行下一步的解析渲染通过以下手段可以减轻cssom带来的影响将script脚本放在页面底部尽可能快的加载css样式表将样式表按照mediatype和mediaquery区分,这样有助于我们将css资源标记成非阻塞渲染的资源非阻塞的资源还是会被浏览器下载,只是优先级较低第三步:把DOM和CSSOM组合成渲染树(rendertree)这个阶段会让原本的dom树和cssom树相结合,成为一颗新的渲染树rendertree值得注意的是:rendertree不会将所有原本的dom树全部构建出来,一些不需要显示的元素则不会被构建到rendertree中渲染树不会添加css中设置为display:none的dom元素渲染树不会添加<head>标签中的元素第四步:在渲染树的基础上进行布局,计算每个节点的几何结构布局渲染:布局(layout):定位坐标和大小,是否换行,各种position,overflow,z-index属性当js脚本中存在修改会影响dom的布局时,会产生回流(Reflow),回流会让浏览器重新执行第四步和第五步的操作第五步,调用GPU绘制,合成图层,显示在屏幕上将渲染树的各个节点绘制到屏幕上,这一步被称为绘制painting当js脚本中存在修改会影响dom样式,但不影响布局时,会产生重绘(Repaint),重绘会让浏览器重新执行第五步的操作

来自:浏览器、网络相关-浏览器页面渲染
03

如何优化浏览器渲染的性能?

1.在合适的时机选择使用Load或者DOMContentLoadedLoad事件触发代表页面中的DOM,CSS,JS,图片已经全部加载完毕。DOMContentLoaded事件触发代表初始的HTML被完全加载和解析,不需要等待CSS,JS,图片加载2.使用不同的图层来渲染页面tips:一般来说,可以把普通文档流看成一个图层。特定的属性可以生成一个新的图层。不同的图层渲染互不影响,所以对于某些频繁需要渲染的建议单独生成一个新图层,提高性能。但也不能生成过多的图层,会引起反作用。通过以下几个常用属性可以生成新图层3D变换:translate3d、translateZwill-changevideo、iframe标签通过动画实现的opacity动画转换position:fixed3.通过优化重绘和回流来减少相应的页面渲染时间重绘和回流是渲染步骤中的一小节,但是这两个步骤对于性能影响很大tips:重绘是当节点需要更改外观而不会影响布局的,比如改变color就叫称为重绘回流是布局或者几何属性需要改变就称为回流。回流必定会发生重绘,重绘不一定会引发回流。回流所需的成本比重绘高的多,改变深层次的节点很可能导致父节点的一系列回流常见引起回流属性和方法添加或者删除可见的DOM元素元素尺寸改变——边距、填充、边框、宽度和高度内容变化,比如用户在input框中输入文字浏览器窗口尺寸改变——resize事件发生时计算offsetWidth和offsetHeight属性设置style属性的值回流影响的范围由于浏览器渲染界面是基于流失布局模型的,所以触发重排时会对周围DOM重新排列,影响的范围有两种1、全局范围:从根节点html开始对整个渲染树进行重新布局。<body><divclass="hello"><h4>hello</h4><p><strong>Name:</strong>BDing</p><h5>male</h5><ol><li>coding</li><li>loving</li></ol></div></body>当p节点上发生reflow时,hello和body也会重新渲染,甚至h5和ol都会收到影响2、局部范围:对渲染树的某部分或某一个渲染对象进行重新布局用局部布局来解释这种现象:把一个dom的宽高之类的几何信息定死,然后在dom内部触发重排,就只会重新渲染该dom内部的元素,而不会影响到外界

来自:浏览器、网络相关-浏览器页面渲染
课程
专栏
js语言和框架-浏览器、网络相关-浏览器页面渲染
3专栏
1课程
3 试题