美文网首页
浏览器环境

浏览器环境

作者: _无味 | 来源:发表于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

    相关文章

      网友评论

          本文标题:浏览器环境

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