- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
前端必的读:浏览器内部工作原理
前端必读:浏览器内部工作原理
目录
一、介绍
二、渲染引擎
三、解析与DOM树构
四、渲染树构
五、布局
六、绘制
七、动态变化
八、渲染引擎的线程
九、CSS2可视模型
英文原文:HowBrowsersWork: Behindthe Scenesof ModernWeb Browsers
一、介绍
浏览器可以被认为是使用最广泛的软件,本文将介绍浏览器的工作原理,我们将看到,
从你在地址栏输入到你看到google主页过程中都发生了什么。
将讨论的浏览器
今天,有五种主流浏览器——IE、Firefo 、Safari、Chrome及Opera。
本文将基于一些开源浏览器的例子——Firefo 、Chrome及Safari,Safari是部分开
源的。
根据W3C (World Wide Web Consortium万维网联盟)的浏览器统计数据,当前
(2011年5月),Firefo 、Safari及Chrome的市场占有率综合已接近60%。(原文为2009
年10月,数据没有太大变化)因此,可以说开源浏览器已经占据了浏览器市场的半壁江山。
浏览器的主要功能
浏览器的主要功能是将用户选择的web资源呈现出来,它需要从服务器请求资源,并
将其显示在浏览器窗口中,资源的格式通常是HTML,也包括PDF、image及其他格式。
用户用URI (UniformResourceIdentifier统一资源标识符)来指定所请求资源的位置,
在网络一章有更多讨论。
HTML和CSS规范中规定了浏览器解释html文档的方式,由W3C组织对这些规范
进行维护,W3C是负责制定web标准的组织。
HTML规范的最新版本是HTML4(/TR/html401/),HTML5还
在制定中 (译注:两年前),最新的CSS规范版本是2(/TR/CSS2),
CSS3也还正在制定中(译注:同样两年前)。
这些年来,浏览器厂商纷纷开发自己的扩展,对规范的遵循并不完善,这为web开发
者带来了严重的兼容性问题。
但是,浏览器的用户界面则差不多,常见的用户界面元素包括:
用来输入URI的地址栏
前进、后退按钮
书签选项
用于刷新及暂停当前加载文档的刷新、暂停按钮
用于到达主页的主页按钮
奇怪的是,并没有哪个正式公布的规范对用户界面做出规定,这些是多年来各浏览器厂
商之间相互模仿和不断改进的结果。
HTML5并没有规定浏览器必须具有的UI元素,但列出了一些常用元素,包括地址栏、
状态栏及工具栏。还有一些浏览器有自己专有的功能,比如Firefo 的下载管理。更多相关
内容将在后面讨论用户界面时介绍。
浏览器的主要构成(High LevelStructure)
浏览器的主要组件包括:
1. 用户界面 - 包括地址栏、后退/前进按钮、书签目录等,也就是你所看到的除了用
来显示你所请求页面的主窗口之外的其他部分。
2. 浏览器引擎 - 用来查询及操作渲染引擎的接口。
3. 渲染引擎 - 用来显示请求的内容,例如,如果请求内容为html,它负责解析html
及css,并将解析后的结果显示出来。
4. 网络 - 用来完成网络调用,例如http请求,它具有平台无关的接口,可以在不同
平台上工作。
5.UI后端 - 用来绘制类似组合选择框及对话框等基本组件,具有不特定于某个平台
的通用接口,底层使用操作系统的用户接口。
6.JS解释器 - 用来解释执行JS代码。
7. 数据存储 - 属于持久层,浏览器需要在硬盘中保存类似cookie 的各种数据,
HTML5定义了web database技术,这是一种轻量级完整的客户端存储技术
图1:浏览器主要组件
需要注意的是,不同于大部分浏览器,Chrome为每个Tab分配了各自的渲染引擎实
例,每个Tab就是一个独立的进程。
对于构成浏览器的这些组件,后面会逐一详细讨论。
二、渲染引擎(The renderingengine)
渲染引擎的职责就是渲染,即在浏览器窗口中显示所请求的内容。
默认情况下,渲染引擎可以显示html、xml文档及图片,它也可以借助插件 (一种浏
览器扩展)显示其他类型数据,例如使用PDF阅读器插件,
您可能关注的文档
- 近代南的京城市社会空间结构.pdf
- 绝妙服的装搭配技巧.pdf
- 历年考的研英语完型填空常考固定搭配.pdf
- 利用地的下空间解决我国粮仓紧缺问题_林在允.pdf
- 林峰:的分权度假与度假地产众筹-绿维创景.pdf
- 浏览器的兼容性解决方案.pdf
- 浏览器的内部工作原理.pdf
- 密码学的引论.pdf
- 面试经的典试题300套与专家点评.pdf
- 南京创的意产业集聚发展研究.pdf
- 2023年江苏省镇江市润州区中考生物二模试卷+答案解析.pdf
- 2023年江苏省徐州市邳州市运河中学中考生物二模试卷+答案解析.pdf
- 2023年江苏省苏州市吴中区中考冲刺数学模拟预测卷+答案解析.pdf
- 2023年江苏省南通市崇川区田家炳中学中考数学四模试卷+答案解析.pdf
- 2023年江西省吉安市中考物理模拟试卷(一)+答案解析.pdf
- 2023年江苏省泰州市海陵区九年级(下)中考三模数学试卷+答案解析.pdf
- 2023年江苏省苏州市高新二中中考数学二模试卷+答案解析.pdf
- 2023年江苏省南通市九年级数学中考复习模拟卷+答案解析.pdf
- 2023年江苏省南通市海安市九年级数学模拟卷+答案解析.pdf
- 2023年江苏省泰州市靖江外国语学校中考数学一调试卷+答案解析.pdf
文档评论(0)