美文网首页
浏览器如何加载渲染页面

浏览器如何加载渲染页面

作者: Kandy | 来源:发表于2018-01-15 17:52 被阅读0次
  1. 用户输入网址,浏览器向服务器发出请求,服务器返回html文件;

  2. 浏览器开始载入全部的html代码,发现<head>标签内有一个<link>标签引用外部CSS文件,浏览器又发出CSS文件的请求,服务器返回这个CSS文件;

  3. 浏览器继续载入html中<body>部分的代码,并且CSS文件已经拿到手了,开始边解析DOM变渲染;

  4. 浏览器在代码中发现一个<img>标签引用了一张图片,向服务器发出请求。此时浏览器不会等到图片下载完,而是继续渲染后面的代码;

  5. 浏览器继续执行时,发现刚刚请求的图片文件返回了,由于图片占用了一定面积,影响了后面段落的排布,因此浏览器需要回过头来重新渲染这部分代码;

  6. 浏览器发现了一个包含一行Javascript代码的<script>标签,赶快运行;

  7. 浏览器发现了两个个包含外部引用的<script>标签,请求并运行,发送了第一个js请求之后不是阻塞,而是会继续发送第二个JS的外部链接请求,结果出现了意外,第二个js的内容先返回了,这时候浏览器不会执行第二个js的代码,而是会等第一个js的代码返回执行后才执行第二个js的代码;

  8. 浏览器发现了一个<script>外部标签,但是包含了async属性,说明是一个异步请求的js,发送请求但是不必等返回执行;

  9. 在Javascript中,脚本执行了这条语句,它命令浏览器隐藏掉代码中的某个<div> (style.display=”none”)。杯具,突然就少了这么一个元素,浏览器不得不重新渲染这部分代码;

  10. 终于等到了</html>的到来,这次渲染终于完成了,触发DOMContentLoaded事件(jQuery中的$(document).ready();方法)。

  11. 等待所有的图片资源、异步加载的JS文件请求完成了,浏览器赶紧触发了onload事件。

另外经过测试(chrome),在onload事件以前,浏览器标题的loading图标都会一直存在。

为方便查看,写了一个小小的测试Demo,为模拟模拟请求的不同延时,页面打开大概需要20s,打开Condole查看。

http://www.eamonning.com/demo/htmlRender/

原文:http://www.eamonning.com/blog/view/498

相关文章

  • JS基础

    浏览器是如何渲染页面和加载页面 解析HTML以重建DOM树(Parsing HTML to construct t...

  • javascript性能优化

    优化页面加载时间html标签加载顺序浏览器加载和执行script标签引入的js时,会暂停页面渲染,直到代码加载并执...

  • css的渲染原理

    一、浏览器是如何渲染和加载页面的 要搞懂这个可以从这个常规流程开始: 1、浏览器的下载顺序是从上到下,渲染的顺序也...

  • 前端性能优化:静态资源加载与优化

    css和js的装载与执行-HTML 页面加载渲染的过程 一个网站在浏览器端是如何进行渲染的呢? HTML渲染过程的...

  • 网页的渲染机制

    网页的渲染机制 参考文章:ScriptJava——了解HTML页面的渲染过程浏览器加载,解析,渲染的过程HTML渲...

  • 网页的渲染机制

    网页的渲染机制 参考文章:ScriptJava——了解HTML页面的渲染过程浏览器加载,解析,渲染的过程HTML渲...

  • 浏览器如何加载渲染页面

    用户输入网址,浏览器向服务器发出请求,服务器返回html文件; 浏览器开始载入全部的html代码,发现 标签内有一...

  • 浏览器的渲染:过程与原理

    浏览器渲染页面的过程 从耗时的角度,浏览器请求、加载、渲染一个页面,时间花在下面五件事情上: DNS 查询 TCP...

  • 2017前端面试题之综合篇(1)

    1 . 浏览器如何渲染? 浏览器的渲染原理简介 专题:浏览器:渲染重绘、重排两三事 浏览器加载和渲染HTML的顺序...

  • 简述浏览器渲染机制

    一 : 为什么要了解浏览器渲染页面的机制,主要还是性能的优化。 了解浏览器如何进行加载,我们可以在引用外部样式文件...

网友评论

      本文标题:浏览器如何加载渲染页面

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