您的位置:首页 > 其它

从输入URL到页面加载完成的过程中都发生了什么事情?

2018-03-11 17:14 288 查看

解析URL

当你在浏览器中输入URL并敲回车之后,浏览器会把URL分成几部分:

1、协议:从计算机获取资源的方式,常见的HTTP、HTTPS等

2、网络地址:域名或者IP,指示网络中的哪一台计算机

3、资源路径:指示在该计算机上获取哪一个资源

DNS域名解析

当浏览器发现网络地址并不是IP,而是域名的时候,浏览器会向DNS服务器发送请求,查找域名对应的IP,如果该DNS服务器没有找到该域名对应的IP,那吗会向上级请求,直到根节点,结果只有两个:要吗找到了,要吗找不到。 (你电脑里的网络设置里面有DNS的服务器IP)

扩展:例如百度、淘宝这些访问量及其大的网站,在DNS域名解析时,在不同的区域或不同网络下解析出来的IP可能是不同的,这就涉及负载均衡的第一步:在DNS解析域名时,将你的访问分配到不同的入口,同时尽可能保证你访问的入口是在所有入口中可能较快的一个。

确定端口

如果网络地址中不包含端口,那么会使用协议默认的端口。HTTP协议默认端口是80,HTTPS协议默认端口是443

发送HTTP请求

当浏览器对域名完成一系列的解析之后,就会构建一个HTTP请求,HTTP属于应用层协议,真正的数据传输是传输层协议TCP完成的,这就涉及到TCP建立连接的“三次握手”:

1、发送端发送带有 SYN 标志的数据包给接收端,并在一定的延迟时间内等待回复

2、接收端收到数据包后传回一个带有 SYN/ACK 标志的数据包以示确认传达信息

3、发送端收到信息后还会发送一个带有 ACK 标志的数据包给接收端以示握手成功,连接建立完成

服务器处理并响应请求

服务器收到客户端发送的HTTP请求后,分析请求报文,并查找相应的请求资源,并返回响应报文。

响应报文中包含一个重要的信息,状态吗:

常见的 4 开头的状态吗一般表示请求出了问题,如 404 表示请求的资源不存在 3 开头的状态吗一般表示重定向,如 301表示永久重定向 5 开头的状态吗一般表示服务器出了问题,如 500 表示服务器出错 2 开头的一般代码成功,如 200

页面渲染



一、解析HTML创建DOM Tree

浏览器解析HTML文档,并构造一颗DOM树(DOM Tree)

二、解析CSS计算样式数据

浏览器构造DOM树的同时,还会解析CSS样式并计算最终的样式数据,生成样式规则。

三、构造渲染树(Render Tree)

根据 DOM Tree 和 样式数据构造一颗渲染树(Render Tree)

渲染树会忽略不需要渲染的DOM元素(如:head标签、display值为none的元素)

四、layout布局

当渲染树构造
aeeb
完成后,浏览器会对渲染树进行布局,即分配固定的坐标点给DOM元素。

五、paint绘制

布局完成后,浏览器将绘制最终的界面给用户
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐