浏览器渲染机制面试_彻底搞懂浏览器渲染页面的机制和原理

1、一道面试题:从用户在浏览器地址栏输入网址,到看到整个页面,中间发生了哪些事情?答:共有三个阶段: ①http请求阶段 ②http响应阶段 ③浏览器渲染阶段在这里我们先重点讲一下浏览器渲染阶段扫盲:① 进程:Process(开了多个饭店)② 线程:Thread(一个饭店雇佣一个服务员是单线程,雇佣多个服务员是多线程)③ 栈内存:Stack (提供一个环境,运行代码)2、浏览器渲染页面的机制和原...
摘要由CSDN通过智能技术生成

1、一道面试题:从用户在浏览器地址栏输入网址,到看到整个页面,中间发生了哪些事情?

答:共有三个阶段: ①http请求阶段 ②http响应阶段 ③浏览器渲染阶段

在这里我们先重点讲一下浏览器渲染阶段

扫盲:

① 进程:Process(开了多个饭店)

② 线程:Thread(一个饭店雇佣一个服务员是单线程,雇佣多个服务员是多线程)

③ 栈内存:Stack (提供一个环境,运行代码)

2、浏览器渲染页面的机制和原理

第一阶段:

当输入url后,比如(http://www.baidu.com),客户端(浏览器)向服务器端(web服务器)发起请求,开始进入Request请求阶段,这个阶段包含:DNS解析、TCP协议的三次握手和四次挥手、HTTPS和HTTP的区别(HTTP2)

第二阶段:

在服务器端的项目磁盘中保存着相对应的页面,这些页面是源代码的格式,请求到以后就开始进入Response阶段:HTTP状态码、304缓存、HTTP报文

第三阶段:

浏览器拿到源代码以后,浏览器在内存条中开辟出一块栈内存,用来给代码的执行提供环境。

只有执行环境是不够的,这时候浏览器同时分配一个主线程去一行一行的解析和执行代码。(前端js是单线程的,原理是浏览器只会分配一个线程来去解析代码)(内存条的空间越高越好,因为这样分出来的空间就越多,做的事情也越多)

而这一个线程去解析源代码的过程:它得先进栈才能执行,所以首先进栈,每一个页面第一行都是:声明文档类型是html,因为单线程一次只能干一件事,所以当前代码执行完以后,主线程一定要出栈,只有出栈,主线程才有时间执行下一行代码。然后再进栈出栈如此这般一行一行的解析。

解析过程中,会遇到,这时候主线程有两种选择。

第一种:自己亲自去服务器,但这个时候浏览器就没人了,下面的代码无法执行,所以必须得将1.css搬过来才能执行,这种方法是不好的。

第二种:让自己的朋友帮忙去服务器搬1.css,自己(主线程)继续执行下面的代码,这个时候浏览器中就有两个人干活了。所以当代码中遇到、、、、等这些所有需要额外加载外部资源文件的请求后,都会单独开辟新的线程去加载资源文件,主线程继续向下执行。

因此可以看出浏览器是多线程程序,但是它只分配了一个线程用来执

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值