大致能分成两个部分:网络通信与页面渲染

一.网络通信

互联网各个网络设备间的通信均基于TCP/IP协议,此协议将整个过程进行分层,由上至下分别为: 应用层、传输层、网络层和数据链路层

1.输入URL

2.应用层用DNS解析域名(DNS协议)

解析url域名,检查本地是否有对应的IP地址,有则返回,没有则请求上级DNS服务器

备注:DNS domain name system,由解析器和域名服务器组成,主要用于解析域名为IP地址

3.应用层发送http请求(HTTP协议)

http请求由请求报头与请求体组成,请求体为请求的数据,请求头包含请求方式(get、post。。)协议(http、https。。)是否包含cookie等信息

4.传输层传输报文(TCP协议)

为了方便传输将IP协议大块的数据分割为以报文段为单位的小数据包,并为其标号,方便服务端还原。

为了保证传输的安全可靠,将经历TCP三次握手:
发送端发送带有SYN标志的数据包给接收端,在一定的时间内等待回复;

接受端接收到数据包并确认无误后发送带有SYN/ACK标志的数据包给发送端,代表已接收,确认无误;

发送端再发送带有ACK标志的数据包给接收端代表握手成功。

SYN: synchronize 同步

ACK:Acknowledgement 确认

5.网络层查询MAC地址(IP协议)

IP协议的作用是把分割好得报文发送给服务端,但在此之前得先知道对方的MAC地址。

IP地址与MAC一一对应,IP地址能随意换,但MAC不会变,提供ARP协议查询到MAC地址

MAC: media access control 媒体访问控制,可理解为物理地址,硬件地址,每个设备都有独一无二的MAC地址

6.数据链路层传输数据

提供数据链路层传输数据,至此客户端发送完毕。

7.服务端接收数据

客户端在数据链路层获取数据,层层上传至应用层,在传递过程中将数据包还原成完整的http请求

8.服务端响应请求

服务端找到资源并返回响应报文,响应报文中包括一个重要的信息——状态码。状态码由三位数字组成,其中比较常见的是200 OK表示请求成功。301表示永久重定向,即请求的资源已经永久转移到新的位置。在返回301状态码的同时,响应报文也会附带重定向的url,客户端接收到后将http请求的url做相应的改变再重新发送。404 not found 表示客户端请求的资源找不到。

9.请求成功后返回html文件,进入页面渲染阶段

二、页面渲染

1.解析HTML构建DOM树,即由节点构成的树

解析和构建同时进行,由上至下地进行解析,这里注意几点:

a.外部样式的加载不会阻塞dom树的构建,但会阻塞其渲染

b.外部样式的加载不会阻塞脚本的加载,但会阻塞其执行

c.如果外部脚本加上async(IR为defer),设为异步,则外部样式不会阻塞其执行

d.动态加载的外部样式不影响脚本的执行

e.script一般放在最后面,因为它的加载和执行会阻塞页面的渲染,也就是说它的加载执行是同步的

2.(style)构建渲染树,即将css样式应用到dom树上,构建CSSOM树

webkit称之为附着

3.(layout)布局

树节点的大小、位置信息等的运算,构建渲染树

4.(painting)绘制

将树绘制在屏幕上。

本文总结自:http://www.cnblogs.com/kongxy/p/4615226.html与http://www.cnblogs.com/dojo-lzz/p/3983335.html

从输入url到浏览器呈现网页发生了什么?的更多相关文章

  1. 从浏览器地址栏输入URL到浏览器呈现数据全过程解析

    一.输入设备(或粘贴)输入 URL,按下 Enter键 或其他按钮开始请求. 二.浏览器开始解析 URL 关于 URL 到相关知识点:什么是URI,URL以及URN,你真的理解了吗. 1.URL 是否 ...

  2. 从输入URL到浏览器显示页面发生了哪些事情---个人理解

    经典面试题:从输入URL到页面显示发生了哪些事情 以前一直都记不住,这次自己理解了一下 用自己的话总结了一次,不对的地方希望大佬给我指出来 1.主机通过DHCP协议获取客户端的IP地址.子网掩码和DN ...

  3. 从输入URL到浏览器显示页面发生了什么

    1.输入网址 当你开始输入网址比如www.cnblogs.com时游览器就可以在书签或者历史记录里面去搜索相关的网址推荐给你. 2.游览器查找域名的IP地址 ① 请求发起后,游览器首先会解析这个域名, ...

  4. 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 3

    备注: 因为文章太长,所以将它分为三部分,本文是第三部分. 第一部分:深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1 第二部分:深入浅出经典面试题:从浏览器中输入URL ...

  5. 在浏览器中输入URL按下回车键后发生了什么

    在浏览器中输入URL按下回车键后发生了什么 [1]解析URL[2]DNS查询,解析域名,将域名解析为IP地址[3]ARP广播,根据IP地址来解析MAC地址[4]分别从应用层到传输层.网络层和数据链路层 ...

  6. 从输入 URL 到浏览器接收的过程中发生了什么事情

    从输入 URL 到浏览器接收的过程中发生了什么事情? 原文:http://www.codeceo.com/article/url-cpu-broswer.html 从触屏到 CPU  首先是「输入 U ...

  7. 从输入 URL 到浏览器接收的过程中发生了什么事情?

    从输入 URL 到浏览器接收的过程中发生了什么事情? What really happens when you navigate to a URL 上面两篇文章都解读的很好,值得阅读. 接下来在总结一 ...

  8. 【ASP.NET Core】EF Core - “影子属性” 深入浅出经典面试题:从浏览器中输入URL到页面加载发生了什么 - Part 1

    [ASP.NET Core]EF Core - “影子属性”   有朋友说老周近来博客更新较慢,确实有些慢,因为有些 bug 要研究,另外就是老周把部分内容转到直播上面,所以写博客的内容减少了一点. ...

  9. 【原】老生常谈-从输入url到页面展示到底发生了什么

    刚开始写这篇文章还是挺纠结的,因为网上搜索“从输入url到页面展示到底发生了什么”,你可以搜到一大堆的资料.而且面试这道题基本是必考题,二月份面试的时候,虽然知道这个过程发生了什么,不过当面试官一步步 ...

随机推荐

  1. .NET CORE 2.0小白笔记(五):配置的热更新、配置的框架设计

    配置的热更新 什么是热更新:一般来说,我们创建的项目都无法做到热更新:即项目无需重启,修改配置文件后读取到的信息就是修改配置之后的 我们只需要吧项目中用到的IOptions改成IOptionsSnap ...

  2. 解读Unity中的CG编写Shader系列3——表面剔除与剪裁模式

    在上一个样例中,我们得到了由mesh组件传递的信息经过数学转换至合适的颜色区间以颜色的形式着色到物体上. 这篇文章将要在此基础上研究片段的擦除(discarding fragments)和前面剪裁.后 ...

  3. MySQL中in(常量列表)的执行计划

    我们在写sql的时候,经常用到in,in后面跟一堆常量列表,如id.有人说in的效率很高,而有人说很低:有人说in能使用索引,还有人说in不能使用索引... 到底是一个怎样的情况呢?我们分析以下几种情 ...

  4. linux把某个文件拷贝到不同的目录下面

    find -name '7*' -type d|xargs -n 1 cp PBClassname.properties

  5. MHA安装配置

    1. 前言 MHA可以在较短的时间内实现自己主动故障检測和故障转移,通常在10-30秒以内;在复制框架中,MHA可以非常好地解决复制过程中的数据一致性问题,因为不须要在现有的replication中加 ...

  6. 为什么jdbc中的resultset只能取一次去第二次就报错了

    引用 6 楼  的回复: 好吧各位,应该写getInt(1)但是我要问的是为什么第二次用会出错 啊,好古老的一个问题... 第二次出错的原因,是因为你创建Statement的时候,没有指定结果集(游标 ...

  7. 【Mac系统】之fiddler下载和安装

    使用教程参考:http://www.cnblogs.com/TankXiao/archive/2012/02/06/2337728.html#request 一.首先,在Mac下安装fiddler时, ...

  8. Gradle 构建工具

    参考文章: 作者:ghui 链接:https://www.zhihu.com/question/30432152/answer/48239946 来源:知乎 著作权归作者所有.商业转载请联系作者获得授 ...

  9. web开发之html5---html5 动画特效舞动的雨伞

    http://www.cnblogs.com/stoneniqiu/p/4199294.html

  10. ubuntu下搭建的lamp环境新建站点

    这几天刚装了一个ubuntu 16.04桌面版,总之来来回回几遍才基本把环境搭建好,本来用apt-get搭建,结果不知道什么原因16.04版不支持装php5 ,提示源放弃了php5版本,不得不使用ph ...