浏览器输入一个url到页面显示发生了什么?

URL解析

首先浏览器会对Url进行解析,这过程中,保留字符(保留字符指& = + $ , / ?等不被转换就会造成url有歧义的字符)会被进行转义(encodeURIComponent:是范围更广的转义api,能够将保留字符转义为UTF-8的字符)

根据dns进行ip查找

  • 例如输入的是www.baidu.com,系统会先去hosts查看相应记录返回对应ip值(操作系统的hosts文件可配置域名对应ip,例如配置github的ip可加速访问giehub)
  • 如果在上一步没找到,会查找本地的dns解析缓存,否则继续向上查找
  • 查找本地dns服务器
  • 查找根dns域名服务器、返回。com域服务器地址,。com域服务器会告诉本地服务器域名解析服务器的地址,最后查询到真正的ip地址后返回用户,并缓存ip
    前端可使用dns预解析加快dns解析的速度
// 打开和关闭DNS预读取
<meta http-equiv="x-dns-prefetch-control" content="off">
// 强制查询特定主机名
<link rel="dns-prefetch" href="//hm.baidu.com">

http请求

HTTP和HTTPS的简单了解
http是基于tcp/ip协议的超文本传输协议,在这个 过程中会经历tcp的三次握手

  • 第一次握手:客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认;
  • 第二次握手:服务器收到syn包,必须确认客户的SYN(ack=j+1),同时自己也发送一个SYN包(syn=k),即SYN+ACK包,此时服务器进入SYN_RECV状态;
  • 第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=k+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手。
    到达web服务器。

这其中路过了应用层、传输层、网络层、数据链路层和物理层(七层网络模型)

缓存

如果之前已经请求过的url浏览器会查看是否命中强制缓存,如果没有与浏览器进行协商缓存,以此来减少网络带宽消耗、降低服务器压力、减少延迟,加快打开页面

关闭tcp链接

执行tcp的四次挥手完成传输任务

解析html

浏览器需要解析html文件才能生成页面

  • 从上到下根据HTML文件构建DOM树
  • 构建CSSOM(CSS Object Model)树:加载解析样式
  • 合并DOM树和CSSOM树,生成渲染树(去除不显示的节点:去除head、display为none的节点)
  • 解析css的同时会继续解析HTML文件,但是遇到js脚本时,会阻塞后续的解析,所以一般将script标签放在dom节点的后面
  • 浏览器布局渲染浏览器重绘和重排

这就是一个大概的过程,还有不重复的部分欢迎指正,我也会不断补充

你可能感兴趣的:(css,js,初学,javascript,前端,开发语言)