美文网首页
浏览器环境

浏览器环境

作者: _无味 | 来源:发表于2018-07-28 19:07 被阅读8次

浏览器环境

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

相关文章

  • 判断当前脚本运行环境,是浏览器还是node

    node环境:global对象undefined 浏览器环境:global对象不为window,则一定不是浏览器环境

  • ES6快速学习(一)变量声明

    ES6 代码在浏览器环境运行!代码在浏览器环境运行!代码在浏览器环境运行!我用的google!!! 变量声明 le...

  • 浏览器特征

    浏览器存储环境

  • php

    介绍: html css js运行环境为浏览器,浏览器在window上运行. 运行环境:wamp phpstudy...

  • 脚注

    1 JavaScript语言可以在非浏览器环境下运行。脱离了浏览器环境束缚的JavaScript不但性能更好,而且...

  • 脚注

    1 JavaScript语言可以在非浏览器环境下运行。脱离了浏览器环境束缚的JavaScript不但性能更好,而且...

  • 关于请求的理解

    在node环境,不存在跨域问题, 在浏览器环境才存在跨域的问题. 在node环境,用不了axios , 在浏览器环...

  • 浏览器环境

    浏览器环境 五大主流浏览器内核1.火狐Firefox: Gecko ...

  • 浏览器环境

    一、script标签的加载浏览器从上到下下载html网页,当碰到srcipt标签会把控制权交给javascript...

  • 浏览器环境

    window对象 history对象 Cookie Web Storage:浏览器端数据储存机制 AJAX CORS通信

网友评论

      本文标题:浏览器环境

      本文链接:https://www.haomeiwen.com/subject/ijxamftx.html