浏览器渲染引擎与阻塞

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析DNS,个人版 1个月
云解析 DNS,旗舰版 1个月
简介: 浏览器渲染引擎与阻塞

浏览器渲染引擎


主要模块


一个渲染引擎主要包括:HTML解析器,CSS解析器,javascript引擎,布局layout模块,绘图模块


  • HTML解析器:解释HTML文档的解析器,主要作用是将HTML文本解释成DOM树。


  • CSS解析器:它的作用是为DOM中的各个元素对象计算出样式信息,为布局提供基础设施


  • Javascript引擎:使用Javascript代码可以修改网页的内容,也能修改css的信息,javascript引擎能够解释javascript代码,并通过DOM接口和CSS树接口来修改网页内容和样式信息,从而改变渲染的结果。


  • 布局(layout):在DOM创建之后,Webkit需要将其中的元素对象同样式信息结合起来,计算他们的大小位置等布局信息,形成一个能表达这所有信息的内部表示模型


  • 绘图模块(paint):使用图形库将布局计算后的各个网页的节点绘制成图像结果


备注:文档对象模型(Document Object Model,简称DOM)


大致的渲染过程


浏览器渲染页面的整个过程:浏览器会从上到下解析文档。


  1. 遇见 HTML 标记,调用HTML解析器解析为对应的 token (一个token就是一个标签文本的序列化)并构建 DOM 树(就是一块内存,保存着tokens,建立它们之间的关系)。


  1. 遇见 style/link 标记调用相应解析器处理CSS标记,并构建出CSS样式树。


  1. 遇见 script 标记 调用javascript引擎 处理script标记、绑定事件、修改DOM树/CSS树


  1. 将 DOM树 与 CSS树 合并成一个渲染树。


  1. 根据渲染树来渲染,以计算每个节点的几何信息(这一过程需要依赖GPU)。


  1. 最终将各个节点绘制到屏幕上。


以上这些模块依赖很多其他的基础模块,包括要使用到网络 存储 2D/3D图像 音频视频解码器 和 图片解码器。 所以渲染引擎中还会包括如何使用这些依赖模块的部分。


阻塞渲染


如果js, html, css之间可以相互影响的都会相互阻塞执行和解析。任何资源(css, img等等)的加载都是异步的。但是没有defer, async属性的script下载会阻塞html的解析。


1.关于css阻塞:


只有link引入的外部css才能够产生阻塞。


  • style标签中的样式:


  • 由html解析器进行解析;


  • 不阻塞浏览器渲染(可能会产生“闪屏现象”);


  • 不阻塞DOM解析;


  • 他是异步解析的,边解析HTML, 边解析style。随即就生成渲染树渲染页面,所以会出现闪屏。


  • link引入的外部css样式(推荐使用的方式):


  • 由CSS解析器进行解析。当浏览器请求文件后,将同步解析css,当其和html都解析完后才渲染页面。


  • 阻塞浏览器渲染(可以利用这种阻塞避免“闪屏现象”)。  


  • 阻塞其后面的js语句的执行


  • 不阻塞DOM的解析(绝大多数浏览器的工作方式)。


  • 优化核心理念:尽可能快的提高外部css加载速度


  • 使用CDN节点进行外部资源加速。


  • 对css进行压缩(利用打包工具,比如webpack,gulp等)。


  • 减少http请求数,将多个css文件合并。


  • 优化样式表的代码


2.关于js阻塞:


  • 阻塞后续DOM解析: 原因:浏览器不知道后续脚本的内容,如果先去解析了下面的DOM,而随后的js删除了后面所有的DOM, 那么浏览器就做了无用功,浏览器无法预估脚本里面具体做了什么操作,例如像document.write 这种操作,索性全部停住,等脚本执行完了,浏览器再继续向下解析DOM。


  • 阻塞页面渲染: 原因:js中也可以给DOM设置样式,浏览器等该脚本执行完毕,渲染出一个最终结果,避免做无用功。


  • 阻塞后续js的执行: 原因:维护依赖关系,例如:必须先引入jQuery再引入bootstrap


  • css的解析和js的执行是互斥的(互相排斥),css解析的时候js停止执行,js执行的时候css停止解析。


  • 无论css阻塞,还是js阻塞,都不会阻塞浏览器加载外部资源(图片、视频、样式、脚本等)原因:浏览器始终处于一种:“先把请求发出去”的工作模式,只要是涉及到网络请求的内容,无论是:图片、样式、脚本,都会先发送请求去获取资源,至于资源到本地之后什么时候用,由浏览器自己协调。这种做法效率很高。


  • WebKit 和 Firefox 都进行了【预解析】这项优化。在执行js脚本时,浏览器的其他线程会预解析文档的其余部分,找出并加载需要通过网络加载的其他资源。通过这种方式,资源可以在并行连接上加载从而提高总体速度。请注意,预解析器不会修改 DOM 树。


  • 在上述的过程中,网页在加载和渲染过程中会触发“DOMContentLoaded”和“onload”事件 分别是在DOM树构建(解析)完成之后,以及DOM树构建完并且网页所依赖的资源都加载完之后


相关文章
|
3月前
|
缓存 JavaScript 前端开发
浏览器渲染:理解页面加载的幕后工作
浏览器渲染:理解页面加载的幕后工作
|
1月前
|
Web App开发 前端开发 JavaScript
认识WebKit浏览器引擎
WebKit是一款开源的浏览器引擎,用于渲染网页内容。它负责将HTML、CSS和JavaScript等网络资源转换为用户在屏幕上看到的图形界面。WebKit是一个跨平台的引擎,可以在多种操作系统上运行,如Windows、macOS、Linux等。
29 2
|
2月前
|
移动开发 前端开发 JavaScript
浏览器端图表渲染技术SVG, VML HTML Canvas
浏览器端图表渲染技术SVG, VML HTML Canvas
22 0
|
3月前
|
前端开发 JavaScript 数据可视化
探索浏览器的内心世界:渲染机制的奥秘
探索浏览器的内心世界:渲染机制的奥秘
探索浏览器的内心世界:渲染机制的奥秘
|
JavaScript 前端开发 容器
从零开始实现一个玩具版浏览器渲染引擎(三)
从零开始实现一个玩具版浏览器渲染引擎(三)
39 0
|
前端开发 JavaScript
从零开始实现一个玩具版浏览器渲染引擎(二)
从零开始实现一个玩具版浏览器渲染引擎(二)
61 0
|
3月前
|
消息中间件 JavaScript 前端开发
前端秘法进阶篇----这还是我们熟悉的浏览器吗?(浏览器的渲染原理)
前端秘法进阶篇----这还是我们熟悉的浏览器吗?(浏览器的渲染原理)
|
3月前
|
消息中间件 前端开发 Java
【面试题】前端必修-浏览器的渲染原理
【面试题】前端必修-浏览器的渲染原理
|
11月前
|
Web App开发 存储 监控
浏览器基础原理-安全: 渲染进程-安全沙盒
浏览器基础原理-安全: 渲染进程-安全沙盒
54 0
|
前端开发 JavaScript API
从零开始实现一个玩具版浏览器渲染引擎(四)
从零开始实现一个玩具版浏览器渲染引擎(四)
69 0