页面加载过程

本文详细介绍了HTTP加载流程,包括DNS域名解析、TCP连接建立、HTTP请求与响应等步骤。在客户端,HTML解析构建DOM树,CSS生成CSSOM树,两者合并为渲染树并计算节点位置,最后绘制页面。JavaScript文件的加载会阻塞HTML渲染,以防DOM被修改。DOM树的建立过程涉及HTML解析、字符解析、语义化和节点创建,完成时触发domContentloaded事件。
摘要由CSDN通过智能技术生成

HTTP加载流程

1.DNS域名解析

2.建立TCP连接

3.客户端发起HTTP请求

4.服务端响应HTTP请求

5.客户端得到HTML代码

6.客户端解析HTML代码,请求HTML代码中的资源(js,css,图片)

7.客户端渲染页面

 

客户端的渲染流程

1.解析HTML,构建DOM树

2.解析CSS,构建CSSOM树

3.将DOM树和CSSOM树合并成为渲染树(render tree)

4.计算渲染树中每个节点的位置

5.通过显卡/GPU绘制页面

阻塞加载

1.当我们浏览器获得HTML文件后,会自上而下的加载,并在加载过程中进行解析和渲染。
2.加载说的就是获取资源文件的过程,如果在加载过程中遇到外部CSS文件和图片,浏览器会另外发送一个请求,去获取CSS文件和相应的图片,这个请求是异步的,并不会影响HTML文件的加载。
3.但是如果遇到Javascript文件,HTML文件会挂起渲染的进程,等待JavaScript文件加载完毕后,再继续进行渲染。
为什么HTML需要等待JavaScript呢?因为JavaScript可能会修改DOM,导致后续HTML资源白白加载,所以HTML必须等待JavaScript文件加载完毕后,再继

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

每天都在掉头发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值