资讯专栏INFORMATION COLUMN

浏览器渲染的那些事(一)

littleGrow / 2300人阅读

摘要:浏览器的主要概念浏览器主要分为这及部分。浏览器会解析,事实上,有三个的类对应这三类文档。浏览器的错误处理相当统一,虽然这不是当前规范的一部分。

今天在推特看到一篇文章《当页面渲染时,浏览器发生了什么》,于是找了些资料,分享一下所得。

浏览器的主要概念

浏览器主要分为这及部分。

User Interface

用户接口。浏览器中的地址栏、前进后退、书签菜单等。除了网页显示区域以外的都是。

Brower engine

浏览器引擎。查询与操作渲染引擎的接口。

Rendering engine

渲染引擎。今天的内容主角就是它~负责显示请求的内容

Networking

网络。用于网络请求,例如HTTP请求。

JavaScript Interpreter

用于解析执行JavaScript代码

UI Backend

绘制基础原件,比如组合框、窗口。

Data Persistence

持久层。HTML5规定了完整的浏览器中的数据库:web database

主要流程

Webkit主要流程如下:

Mozilla的Gecko渲染引擎主要流程

由图可以发现,两个引擎过程基本相同。主要有三个步骤:

解析。浏览器会解析HTML/SVG/XHTML,事实上,webkit有三个C++的类对应这三类文档。浏览器解析这三种文件会产生一个DOM Tree;解析CSS,产生style rules;解析Javacript,主要通过DOM API和CSSOM API来操作DOM Tree和CSS Rule Tree

解析完成后,浏览器引擎会通过DOM Tree和CSS Rule Tree来构造Rendering Tree。

调用操作系统Native GUI的API绘制。

两个引擎的差别在于它们起的名字不一样,即语义差别:

webkit把可视化好的可视元素成为Render Tree,用Layout来表示元素的布局

Gecko把可视化好的可视元素成为Frame Tree,每个元素就是一个frame,元素的布局成为Reflow

当然,也不是只有语义差别。还有一个细小的差别差别在于:
Gecko在HTML与DOM树之间还多一个层content Sink,这是创建DOM对象的工厂。

DOM解析

解析由两部分组成:分词+构建树。
HTML5规范中,HTML解析流程如下图:

分词是词法分析,把输入解析成符号序列。
构建树的过程就是在不断处理分词器完成的节点。除了把元素添加到DOM树上,还会将其添加到一个开放元素堆栈,用于纠正嵌套错误和标签未关闭错误。
但其实浏览器比我们想象的更强大更包容。浏览器的错误处理相当统一,虽然这不是当前HTML规范的一部分。当很多格式不良的HTML文档出现在很多网站,浏览器会尝试用和其他浏览器一样的方式修复错误。



    Web page parsing


    

Web page parsing

This is an example Web page.

DOM Tree解析如下:

CSS解析

Webkit使用Flext and Bison 解析器生成器,通过CSS语法文件自动创建解析器。Bison会创建自下而上的移位归约解析器。Firefox使用的是人工编写的自上而下的解析器。

关于创建树的流程以及样式计算、重排重绘等部分,留到下一篇文章再写咯~

参考文献:

浏览器内部工作原理

浏览器的渲染原理简介

How browsers work

有关网页渲染,每个前端开发者都该知道的那点事

前端文摘:深入解析浏览器的幕后工作原理

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/115264.html

相关文章

  • 览器渲染那些之 Reflow、Repaint

    摘要:原文链接浏览器渲染那些事之浏览器内核渲染引擎在各个浏览器厂商你追我赶的形势下,截止今日,产生了很多不同的浏览器,各个浏览器本质大同小异,核心部分基本相似,由渲染引擎和引擎组成。 原文链接 浏览器渲染那些事之 Reflow、Repaint 浏览器内核(渲染引擎) 在各个浏览器厂商你追我赶的形势下,截止今日,产生了很多不同的浏览器,各个浏览器本质大同小异,核心部分基本相似,由渲染引擎和 J...

    morgan 评论0 收藏0
  • 览器渲染那些()

    摘要:浏览器的主要概念浏览器主要分为这及部分。浏览器会解析,事实上,有三个的类对应这三类文档。浏览器的错误处理相当统一,虽然这不是当前规范的一部分。 今天在推特看到一篇文章《当页面渲染时,浏览器发生了什么》,于是找了些资料,分享一下所得。 浏览器的主要概念 showImg(https://segmentfault.com/img/bVvOAv); 浏览器主要分为这及部分。 User In...

    cucumber 评论0 收藏0
  • 览器渲染那些()

    摘要:浏览器的主要概念浏览器主要分为这及部分。浏览器会解析,事实上,有三个的类对应这三类文档。浏览器的错误处理相当统一,虽然这不是当前规范的一部分。 今天在推特看到一篇文章《当页面渲染时,浏览器发生了什么》,于是找了些资料,分享一下所得。 浏览器的主要概念 showImg(https://segmentfault.com/img/bVvOAv); 浏览器主要分为这及部分。 User In...

    sorra 评论0 收藏0
  • 览器渲染那些(二)

    摘要:接上一篇浏览器渲染的那些事一继续说。哈希表的选择器各不相同,包括,标记名称等。例如,如果选择器是,就把规则放入的哈希表中还有一种通用哈希表,适合不属于上述类别的规则。 接上一篇浏览器渲染的那些事(一)继续说。 构建呈现树 Render Tree/Frame Tree 渲染的流程: 在这部分我们来讲一下构建Render Tree的过程。呈现树主要是负责布局并将自身及其子元素绘制出来。We...

    沈建明 评论0 收藏0

发表评论

0条评论

littleGrow

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<