JS高级编程课件02_深入浏览器的渲染原理.pdf

JS高级编程课件02_深入浏览器的渲染原理.pdf

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共15页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

深入浏览器的渲染原理

王红元coderwhy

目录

1网页的解析过程

content

2浏览器渲染流程

3回流和重绘解析

4合成和性能优化

5defer和async属性

coderwhy网页被解析的过程

◼大家有没有深入思考过:一个网页URL从输入到浏览器中,到显示经历过怎么样的解析过程呢?

◼要想深入理解下载的过程,我们还要先理解,一个index.html被下载下来后是如何被解析和显示在浏览器上的.

coderwhy浏览器的内核

◼常见的浏览器内核有

Trident(三叉戟):IE、360安全浏览器、搜狗高速浏览器、百度浏览器、UC浏览器;

Gecko(壁虎):MozillaFirefox;

Presto(急板乐曲)-Blink(眨眼):Opera

Webkit:Safari、360极速浏览器、搜狗高速浏览器、移动端浏览器(Android、iOS)

Webkit-Blink:GoogleChrome,Edge

◼我们经常说的浏览器内核指的是浏览器的排版引擎:

排版引擎(layoutengine),也称为浏览器引擎(browserengine)、页面渲染引擎(renderingengine)或样版引擎。

◼也就是一个网页下载下来后,就是由我们的渲染引擎来帮助我们解析的。

coderwhy渲染引擎如何解析页面呢?

◼渲染引擎在拿到一个页面后,如何解析整个页面并且最终呈现出我们的网页呢?

我们之前学习过下面的这幅图,现在让我们更加详细的学习它的过程;

coderwhy渲染页面的详细流程

◼更详细的解析过程如下:

◼/en/tutorials/internals/howbrowserswork

coderwhy解析一:HTML解析过程

◼因为默认情况下服务器会给浏览器返回index.html文件,所以解析HTML是所有步骤的开始:

◼解析HTML,会构建DOMTree:

coderwhy解析二–生成CSS规则

◼在解析的过程中,如果遇到CSS的link元素,那么会由浏览器负责下载对应的CSS文件:

注意:下载CSS文件是不会影响DOM的解析的;

◼浏览器下载完CSS文件后,就会对CSS文件进行解析,解析出对应的规则树:

我们可以称之为CSSOM(CSSObjectModel,CSS对象模型);

coderwhy解析三–构建RenderTree

◼当有了DOMTree和CSSOMTree后,就可以两个结合来构建RenderTree了

◼注意一:link元素不会阻塞DOMTree的构建过程,但是会阻塞RenderTree的构建过程

这是因为RenderTree在构建时,需要对应的CSSOMTree;

◼注意二:RenderTree和DOMTree并不是一一对应的关系,比如对于display为none的元素,压根不会出现在rendertree中;

coderwhy解析四–布局(layout)和绘制(Paint)

◼第四步是在渲染树(RenderTree)上运行布局(Layout)以计算每个节点的几何体。

渲染树会表示显示哪些节点以及其他样式,但是不表示每个节点的尺寸、位置等信息;

布局是确定呈现树中所有节点的宽度、高度和位置信息;

◼第五步是将每个节点绘制(Paint)到屏幕上

在绘制阶段,浏览器将布局阶段计算的每个frame转为屏幕上实际的像素点;

包括将元素的可见部分进行绘制,比如文本、颜色、边框、阴影、替换元素(比如img)

coderwhy回流和重绘

◼理解回流reflow:(也可以称之为重排)

文档评论(0)

yzs890305 + 关注
实名认证
内容提供者

计算机二级持证人

该用户很懒,什么也没介绍

领域认证该用户于2024年11月02日上传了计算机二级

1亿VIP精品文档

相关文档