浏览器环境

浏览器环境

五大主流浏览器内核
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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值