Web/01-HTML/02-浏览器的介绍.md

104 lines
3.5 KiB
JavaScript
Raw Normal View History

2020-03-22 12:11:51 +08:00
## 常见的浏览器
浏览器是网页运行的平台常见的浏览器有谷歌ChromeSafari火狐FirefoxIEEdgeOpera等如下图所示
![](http://img.smyhvae.com/20191204_1900.png)
我们重点需要学习的是 Chrome 浏览器
## 浏览器的市场占有份额
浏览器的市场占有份额<https://tongji.baidu.com/research/site?source=index#browser>
![](http://img.smyhvae.com/20200322_1058.png)
上面这张图的统计时间是2020年2月
## 浏览器的组成
浏览器分成两部分
- 1渲染引擎浏览器内核
- 2JS 引擎
### 1渲染引擎浏览器内核
浏览器所采用的渲染引擎也称之为浏览器内核用来解析 HTML与CSS渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息
**渲染引擎是浏览器兼容性问题出现的根本原因**
渲染引擎的英文叫做 Rendering Engine通俗来说它的作用就是读取网页内容计算网页的显示方式并显示在页面上
常见浏览器的内核如下
|浏览器 | 内核|
|:-------------:|:-------------:|
| chrome | Blink |
| 欧鹏 | Blink |
|360安全浏览器| Blink|
|360极速浏览器| Blink|
|Safari|Webkit|
|Firefox 火狐|Gecko|
|IE| Trident |
备注360的浏览器以前使用的IE浏览器的Trident内核但是现在已经改为使用 chrome 浏览器的 Blink内核
另外移动端的浏览器内核是什么大家可以自行查阅资料
### 2JS 引擎
也称为 JS 解释器 用来解析网页中的JavaScript代码对其处理后再运行
2020-05-23 17:58:43 +08:00
浏览器本身并不会执行JS代码而是通过内置 JavaScript 引擎(解释器) 来执行 JS 代码 JS 引擎执行代码时会逐行解释每一句源码转换为机器语言然后由计算机去执行所以 JavaScript 语言归为脚本语言会逐行解释执行
2020-03-22 12:11:51 +08:00
常见浏览器的 JS 引擎如下
|浏览器 | JS 引擎|
|:-------------:|:-------------|
|chrome / 欧鹏 | V8 |
|Safari|Nitro|
|Firefox 火狐|SpiderMonkey1.0-3.0/ TraceMonkey3.5-3.6/ JaegerMonkey4.0-|
|Opera|Linear A4.0-6.1/ Linear B7.0-9.2/ Futhark9.5-10.2/ Carakan10.5-|
|IE|Trident |
参考链接
- [主流浏览器内核及JS引擎](https://juejin.im/post/5ada727c518825670b33a584)
## 浏览器工作原理
2020-04-01 16:18:21 +08:00
> 这一小段有些深入小白可以暂时跳过以后再来看
2020-03-22 12:11:51 +08:00
![](http://img.smyhvae.com/20180124_1700.png)
2021-04-06 21:46:57 +08:00
1User Interface 用户界面我们所看到的浏览器
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
2Browser engine 浏览器引擎用来查询和操作渲染引擎
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
3Rendering engine 用来显示请求的内容负责解析HTMLCSS
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
4Networking 网络负责发送网络请求
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
5JavaScript Interpreter(解析者) JavaScript解析器负责执行JavaScript的代码
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
6UI Backend UI后端用来绘制类似组合框和弹出窗口
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
7Data Persistence(持久化) 数据持久化数据存储 cookieHTML5中的sessionStorage
2020-03-22 12:11:51 +08:00
参考链接
2021-05-06 11:01:06 +08:00
- 英文版[How Browsers Work: Behind the scenes of modern web browsers](https://www.html5rocks.com/en/tutorials/internals/howbrowserswork/)
2020-03-22 12:11:51 +08:00
2021-05-06 11:01:06 +08:00
- 中文版[浏览器的工作原理新式网络浏览器幕后揭秘](https://www.html5rocks.com/zh/tutorials/internals/howbrowserswork/)
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
---
2020-03-22 12:11:51 +08:00
2021-04-06 21:46:57 +08:00
本作品采用[知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议](https://creativecommons.org/licenses/by-nc-sa/4.0/)进行许可。
2020-03-22 12:11:51 +08:00
2021-05-06 11:01:06 +08:00
![](https://img.smyhvae.com/20210329_1930.png)