从输入URL后浏览器的渲染逻辑
从输入URL到浏览器渲染页面需要经过很多过程,本文简单说明下各个环节的内容
主要渲染节点如下:
一、浏览器进程说明
出于安全考虑,打开一个浏览器的Tab页签,会生成1个浏览器主进程、1个网络进程、1个GPU进程以及多个渲染进程和多个插件进程,所以不同页签数据无法相互访问,
多个进程也可以提高渲染的速度,最直接的现象就是打开浏览器后,任务管理器会出现多个Google页面的进程但是渲染进程与其他的进程有些区别,可见下文
1. 浏览器主进程:中控系统,主要复杂与用户交互、子进程管理和文件存储的功能
2. 网络进程:面向渲染进程和浏览器主进程提供网络下载功能。
3. 渲染进程:把下载到的HTML、css、JavaScript、图片等资源解析为可以显示和交互的页面,由于下载的代码可能存在恶意代码,所以渲染进程在安全沙箱允许,提供系统的安全性;
还有一个注意点,如果多个页签打开同一个网站,则这几个网站共用一个渲染进程,提高渲染效率,最直观现象:比如某个页签卡死了,则其他页签同网站的代码也卡死了,但是不同域的网站却可以正常操作。
新开一个页签一般只有一个渲染进程,但是如果页面中包含iframe时会存在多个渲染进程
4. GPU进程:最初用于渲染3D效果,后来也被用于渲染UI
5. 插件进程:负责浏览器插件的运行,因为插件崩溃机率较大,所以运行在沙箱环境中
二、页面渲染的主要步骤
1. 输入URL,,组装完整的URL
2. 检查本地是否有IP地址缓存(如果没有则进行DNS查询),主进程通过IPC把URL发送给网络进程
3. 查找本地资源,资源是否在有效期内
3. 进入TCP队列,然后创建TCP连接(三次握手)
4. 发送HTTP请求,包含cookie,请求体等信息
5. 网络进程接受请求,判断请求体状态(200: 根据响应头的Content-type决定如何响应; 301/302:重定向;304:资源有缓存)
6. 准备渲染进程,判断是否是同域站点,决定是否复用渲染进程
7. 浏览器主进程收到网络进程的响应头数据,像渲染进程发送【提交文档】消息
8. 渲染进程收到【提交文档】消息后,与网络进程建立传输通道
9. 主进程收到【确认提交】消息后,移除就文档、更新界面和地址栏等内容(期间浏览器加载中的小圆圈状态会从请求时的逆时针变为渲染阶段的顺时针旋转)
10. 收到页面,解析HTML标签,构建DOM树
11. 遇到CSS则进行CSS下载和解析生成CSS树(CSSOM,使用window.getComputedStyle可以获取查看),每个节点具体的样式,然后继续解析HTML;如果标签中有defer和async属性,则解析DOM和下载资源同步执行
12. 接下来则是进行页面布局,DOM和CSSOM结合生成渲染树,计算每个节点的位置和样式
13. 每个节点生成专用图层,包含位置属性,颜色值和透明度等
14. 渲染引擎对图层树进行渲染,如果期间DOM的颜色有变化则会触发重绘功能,如果位置有变化或者出现DOM增删则会触发重排功能
从输入URL后浏览器的渲染逻辑的更多相关文章
- 输入url后浏览器干了些什么(详解)
输入url后浏览器干了些什么(详解) DNS(Domain Name System, 域名系统) 解析 DNS解析的过程就是寻找哪台机器上有你真正需要的资源过程.但你在浏览器张红输入一个地址时,例如: ...
- 输入URL后浏览器的过程
In this article, I want my readers to get a picture of a very basic concept of the web world. Previo ...
- 在浏览器输入URL后发生了什么?
摘录部分一:https://www.cnblogs.com/kongxy/p/4615226.html 从输入URL到浏览器显示页面发生了什么 当在浏览器地址栏输入网址,如:www.baidu.com ...
- 在浏览器输入 URL 后会发生什么?超级详细介绍
一个古老的面试问题:当你在浏览器中输入whosmall.com并且按下回车之后发生了什么? 不过我们不再局限于平常的回答,而是想办法回答地尽可能具体,不遗漏任何细节. 这将是一个协作的过程,所以深入挖 ...
- 在浏览器输入url后并回车发生了哪些过程
1.解析URL ________________________________________________________________________ 关于URL: URL(Universa ...
- 【转】浏览器中输入url后发生了什么
原文地址:http://www.jianshu.com/p/c1dfc6caa520 在学习前端的过程中经常看到这样一个问题:当你在浏览器中输入url后发生了什么?下面是个人学习过程中的总结,供个人复 ...
- 在浏览器中输入URL后,执行的全部过程。会用到哪些协议?(一次完整的HTTP请求过程)
在浏览器中输入URL后,执行的全部过程.会用到哪些协议?(一次完整的HTTP请求过程) 整个流程如下: 域名解析 为了将消息从你的PC上传到服务器上,需要用到IP协议.ARP协议和OSPF协议. 发起 ...
- 从输入 URL 到浏览器接收的过程中发生了什么事情
从输入 URL 到浏览器接收的过程中发生了什么事情? 原文:http://www.codeceo.com/article/url-cpu-broswer.html 从触屏到 CPU 首先是「输入 U ...
- 输入URL到浏览器显示页面的过程,搜集各方面资料总结一下
面试中经常会被问到这个问题吧,唉,我最开始被问到的时候也就能大概说一些流程.被问得多了,自己就想去找找这个问题的全面回答,于是乎搜了很多资料和网上的文章,根据那些文章写一个总结. 写得不好,或者有意见 ...
- 从输入 URL 到浏览器接收的过程中发生了什么事情?
从输入 URL 到浏览器接收的过程中发生了什么事情? What really happens when you navigate to a URL 上面两篇文章都解读的很好,值得阅读. 接下来在总结一 ...
随机推荐
- Java连接phoenix问题
这个错误的原因是找不到文件,所以要在本地配置一下hadoop的环境变量 下载 将其中hadoop 这个文件放在c盘windows下system32目录下就ok了
- zookeeper JavaApi 查询节点
/** * 1.查询数据 :get * 2.查询子节点 : ls * 3.查询节点的状态信息 :ls -s * * */ @Test public void testGet1() throws Exc ...
- LR(0)分析法
LR(0)是一种自底向上的语法分析方法.两个基本动作是移进和规约. 具体例子如下 已知文法G[E] (1) E→aА (2) E→bB (3) A→cА (4) A→d (5) B→cB (6) B→ ...
- 如何对连续型数据进行离散化处理,并进行OneHot编码?
如何对连续型数据进行离散化处理,并进行OneHot编码,最终将OneHot编码作为特征因子输入模型? 什么是OneHot编码 One-Hot编码是分类变量作为二进制向量的表示.这首先要求将分类值映射到 ...
- Odoo16—权限控制
odoo的权限控制是通过用户组来实现的,在用户组中配置控制权限,然后再添加用户到用户组中,从而实现对用户的访问和操作权限控制.一个用户可以属于多个用户组,用户最终的权限范围取决于所属用户组权限的并集. ...
- 解析RC4加密算法
一.简介 RC4(Rivest Cipher 4)是一种对称加密算法,由Ronald L. Rivest于1987年为其所在的公司RSA Data Security Inc. 开发.作为一种可变密钥长 ...
- Python中的协程、线程和进程
一.协程与多线程和多进程一起使用有什么不同 协程.多线程和多进程都是实现程序并发执行的方法,不过它们在工作方式和适合的应用场景上存在一些区别. 1.协程(Coroutine) 协程是在单一线程 ...
- Hudi自带工具DeltaStreamer的实时入湖最佳实践
摘要:本文介绍如何使用Hudi自带入湖工具DeltaStreamer进行数据的实时入湖. 本文分享自华为云社区<华为FusionInsight MRS实战 - Hudi实时入湖之DeltaStr ...
- FusionInsight怎么帮「宇宙行」建一个好的「云数据平台」?
摘要:基于数据湖架构,应用效率得以极大提升.经过几年发展,当前集群规模已经达到1000多节点,数据量几十PB,日均处理作业数大概是10万,赋能于180多个总行应用和境内外41家分行及子公司. 本文分享 ...
- 如何使用appuploader制作描述文件
如何使用appuploader制作描述文件 承接上文我们讲述了怎么制作证书,本文我们来看下怎么制作描述文件吧.制作描述文件前我们首先我们来添加一个测试设备,后面再制作描述文件. 1.添加测试设备 ...