博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浏览器的渲染原理简介
阅读量:6259 次
发布时间:2019-06-22

本文共 1134 字,大约阅读时间需要 3 分钟。

看到这个标题大家一定会想到这篇神文《》,这篇文章把浏览器的很多细节讲得很细,而且也被。为什么我还想写一篇呢?因为两个原因, 

  • 这篇文章太长了,阅读成本太大,不能一口气读完。
  • 花了大力气读了这篇文章后可以了解很多,但似乎对工作没什么帮助。

所以,我准备写下这篇文章来解决上述两个问题。希望你能在上班途中,或是坐马桶时就能读完,并能从中学会一些能用在工作上的东西。 

浏览器工作大流程 

废话少说,先来看个图: 

浏览器的渲染原理简介



从上面这个图中,我们可以看到那么几个事: 

1)浏览器会解析三个东西: 

  • 一个是HTML/SVG/XHTML,事实上,Webkit有三个C++的类对应这三类文档。解析这三种文件会产生一个DOM Tree。
  • CSS,解析CSS会产生CSS规则树。
  • Javascript,脚本,主要是通过DOM API和CSSOM API来操作DOM Tree和CSS Rule Tree.

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

  • Rendering Tree 渲染树并不等同于DOM树,因为一些像Header或display:none的东西就没必要放在渲染树中了。
  • CSS 的 Rule Tree主要是为了完成匹配并把CSS Rule附加上Rendering Tree上的每个Element。也就是DOM结点。也就是所谓的Frame。
  • 然后,计算每个Frame(也就是每个Element)的位置,这又叫layout和reflow过程。

3)最后通过调用操作系统Native GUI的API绘制。 

DOM解析 

HTML的DOM Tree解析如下: 

Html代码 
  1. <</span>html>  
  2. <</span>html>  
  3. <</span>head>  
  4.     <</span>title>Web page parsing</</span>title>  
  5. </</span>head>  
  6. <</span>body>  
  7.     <</span>div>  
  8.         <</span>h1>Web page parsing</</span>h1>  
  9.         <</span>p>This is an example Web page.</</span>p>  
  10.     </</span>div>  
  11. </</span>body>  
  12. </</span>html>  


上面这段HTML会解析成这样: 


浏览器的渲染原理简介



下面是另一个有SVG标签的情况。 


浏览器的渲染原理简介




CSS解析 

CSS的解析大概是下面这个样子(下面主要说的是Gecko也就是Firefox的玩法),假设我们有下面的HTML文档: 

Html代码 

转载于:https://www.cnblogs.com/tnnyang/p/4073335.html

你可能感兴趣的文章
刨根问底-struts-怎么加载配置的相应的信息
查看>>
解决mysql数据库大小写敏感问题
查看>>
jsp页面组成
查看>>
LCS记录
查看>>
C++开源跨平台类库集
查看>>
everything搜索工具小技巧
查看>>
一个 Sql语句优化的问题- STATISTICS 统计信息
查看>>
你不知道的KVO的内部实现
查看>>
转】MyEclipse10安装Log4E插件
查看>>
windows server2012r2 安装NET Framework 3.5
查看>>
[osg][osgEarth][原]基于OE自定义自由飞行漫游器(初级版)
查看>>
Java遇见HTML——JSP篇之JSP基础语法
查看>>
导出一个数据库中的表中的某一条数据
查看>>
JQuery初体验
查看>>
全球顶级黑客对决AI GeekPwn2017黑客大赛看点全面曝光
查看>>
浅析前端开发中的 MVC/MVP/MVVM 模式
查看>>
toString、equals和hashCode重写
查看>>
sizeof 和strlen的区别
查看>>
Python与C++引用分析
查看>>
误删一个用户 引起数据不准确问题
查看>>