浏览器环境
五大主流浏览器内核
1.火狐Firefox: Gecko 引擎
2.苹果Safari: WebKit 引擎
3.谷歌Chrome: Blink 引擎
4.IE浏览器: Trident 引擎
5.欧朋Opera: presto引擎
浏览器内核主要分成两部分:
渲染引擎(layoutengineerRenderingEngine)和JS引擎。
渲染引擎:负责取得网页的内容(HTML、XML、图像等等)、整理讯息(例如加入CSS等),以及计算网页的显示方式,然后会输出至显示器或打印机。浏览器的内核的不同对于网页的语法解释会有不同,所以渲染的效果也不相同。所有网页浏览器、电子邮件客户端以及其它需要编辑、显示网络内容的应用程序都需要内核。
简单说就是把html和css音频视频等,转化成UI可以看到的东西
JS引擎则:解析和执行javascript来实现网页的动态效果。
最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独立,内核就倾向于只指渲染引擎
浏览器渲染的工作原理
1.浏览器一边下载 HTML 网页,一边开始解析。也就是说,不等到下载完,就开始解析。
2.解析过程中,浏览器发现<script>元素,就暂停解析,把网页渲染的控制权转交给 JavaScript 引擎。
3.如果<script>元素引用了外部脚本,就下载该脚本再执行
4.JavaScript 引擎执行完毕,控制权交还渲染引擎,恢复往下解析 HTML 网页。
如果外部脚本加载时间过长(一直无法完成加载),那么浏览器就会一直
等待脚本下载完成,造成网页长时间失去响应,浏览器就会呈现"假死"
状态,这被称为"阻塞效应"
为了避免“阻塞效应”,我们要把js放在最后。
为了解决脚本文件下载阻塞网页渲染的问题,一个方法是对<script>元素加入defer属性。它的作用是延迟脚本的执行,等到 DOM 加载生成后,再执行脚本
添加defer属性渲染顺序
1.浏览器开始解析 HTML 网页。
2.解析过程中,发现带有defer属性的<script>元素。
3.浏览器继续往下解析 HTML 网页,同时并行下载<script>元素加载的外部脚本。
4.浏览器完成解析 HTML 网页,此时再回过头执行已经下载完成的脚本。
添加async属性渲染顺序
1.浏览器开始解析 HTML 网页。
2.解析过程中,发现带有async属性的script标签。
3.浏览器继续往下解析 HTML 网页,同时并行下载<script>标签中的外部脚本。
4.脚本下载完成,浏览器暂停解析 HTML 网页,开始执行下载的脚本。
5.脚本执行完毕,浏览器恢复解析 HTML 网页。
我们无法控制js的加载顺序,哪个先加载完成哪个先运行
何时使用async和defer
如果加载的两个外部文件没有依赖关系,就可以用async,有依赖关系,就要用defer属性。
如果两个都写,就执行async