Chrome浏览器是如何工作的?(二)

简介: Chrome浏览器是如何工作的?(二)

image.png

Chrome浏览器是如何工作的?(二)


image.png

七.页面绘制 Paint


      经过前面几个步骤,此时完整的页面结构已经差不多可以绘制了。但是还有一个问题在于 Render 进程还不知道你是否在某些 DOM 元素 设置了绝对定位如 display:absolute、sticky 或者调整了一些元素的 z-index 属性。因为我们之前说过,绘制 DOM 的时候,Render 是不关心样式的,所以下一步就是解决这个问题的。

这时 Render 进程的主线程(Main Thread)会去遍历 Layout Tree 从而绘制出一个绘制记录表(Paint Record),来保证页面绘制的顺序不会出错。

当主线程遍历完成后,会生成图层树Layer Tree

随后 Render 进程的主线程会把设计图交付给合成器线程,合成器线程拿着设计图(Layer Tree)和绘制记录表(Paint Record)将这些信息绘制成人类可以识别的像素点坐标信息。这个过程被称为栅格化Rastering

合成器线程的栅格原理并不是从页面的最顶部一直渲染到最底部的过程。而是将整个页面分为多个图块交给多个栅格化线程(Raster Thread),类似于下图这样。

image.png

栅格线程将每个图块的栅格化信息保存在 GPU 的内存中。

image.png

当整个页面都栅格化完成后,主线程此时将收集栅格线程生成的 Draw Quads 信息,这些信息记录了每个图块在内存中的位置和每个图块需要在页面的哪个位置渲染的信息。(再通俗易懂一点讲的话,可以这样简单理解 const Draw = x 坐标,y 坐标等绘制信息

根据这些 Draw Quads 的信息,合成器线程会生成一个合成器帧Compositor Frame)。然后这个合成器帧会通过 IPC (inter process communication)传送给浏览器进程。就是这个)

image.png

紧接着浏览器进程合成器帧传递给 GPU 进程。(不要忘记我们之前第一篇所说的,浏览器进程负责调度各个进程之间的合作)

image.png

最终 GPU 将页面渲染到页面上,恭喜你🎉!经历九九八十一难你终于看到了最终的页面效果。

我们可以在 Chrome 的调试工具下,选择 Performance 选项卡来发现浏览器绘制的每一帧对应的页面。

image.png

八.重排(reflow)和重绘(repaint)


此时如果我们开始滚动页面,合成器线程就会再次生成一个合成器帧通过 IPC 传递给浏览器进程,浏览器进程再传递给 GPU , GPU 再次绘制新的一帧,然后呈现出新的页面到屏幕上。此时就会重新进行 Layout 以后的所有步骤。这个过程我们叫做重排(reflow)。由此可见重排的代价是很大的

image.png

常见会引发重排的动作比如更改 DOM元素 高度,定位、伪元素等等。(不是本文重点,请自行查阅相关知识)

当页面只是简单的更改了背景颜色等动作时,只会触发样式计算绘制,并不会进行其它的任务。这个过程我们叫做重绘(repaint)

image.png

从上面的图我们可以清晰的看到,无论是重排还是重绘都是进行在主线程上的。别忘了还有一重量级选手 JavaScript 也是运行在主线程上的。那么如果在同一时间进行了大量的重绘重排,其中还穿插着 JS 代码的运行,那么就会造成页面的卡顿。“卡”的产生原因我们继续往下看。

九.渲染帧数


目前我们主流的显示器帧数都是在60HZ以上。也就是说我们电脑的性能支持显示器在 1000ms 内完成60次页面的刷新,(并不是指F5刷新的那个刷新...😂)那么我们1000/60=16.7777可以得出。浏览器必须在16ms的间隔绘制出新的一帧,才能保证用户觉得“不卡”。

进一步解释就是浏览器要在16ms内完成一次下图的调度过程,用户才能得到最好的体验。那么当主线程 JS 的代码过于耗时的时候,无法及时归还主线程在以便在16ms内进行 LayoutLayer,那么就造成“卡了一下”的现象。(想象打游戏丢帧)

image.png

十.Transform的优点


我们经常会看到建议使用Transform来代替topleft等位置变化属性。其根本原因就是:

      Transform 属性完成的动画不会重新 LayoutLayer,而是直接运行在合成器线程栅格线程中的的那也就意味着它不会抢夺主线程的使用,也不会影响JS代码的执行。

image.png

饮水思源:

感谢B站up主 objtube的卢克儿 的这期视频,让我通俗易懂的理解了大致的流程。(🍉文章内部分截图来自于这期视频)

image.png


相关实践学习
部署Stable Diffusion玩转AI绘画(GPU云服务器)
本实验通过在ECS上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。
相关文章
|
3月前
|
Web App开发
在 HTML 中禁用 Chrome 浏览器的 Google 翻译功能
在 html 标签中添加 translate=“no” 属性,浏览器将不会翻译整个页面。
205 0
|
3月前
|
Web App开发 JavaScript 前端开发
从零开始,轻松打造个人化Chrome浏览器插件
从零开始,轻松打造个人化Chrome浏览器插件
130 0
|
7天前
|
Web App开发
Chrome——谷歌浏览器chrome如何模拟其他客户端
Chrome——谷歌浏览器chrome如何模拟其他客户端
24 1
Chrome——谷歌浏览器chrome如何模拟其他客户端
|
2月前
|
Web App开发 前端开发 JavaScript
Chrome 浏览器中执行 JavaScript
Chrome 浏览器中执行 JavaScript
121 0
|
1天前
|
Web App开发
成功解决Chrome浏览器 控制台下看不到接口信息的问题
这篇文章提供了解决Chrome浏览器控制台不显示接口信息问题的方法,包括检查过滤设置和确保“保留日志”开关已打开。
成功解决Chrome浏览器 控制台下看不到接口信息的问题
|
11天前
|
Web App开发 前端开发 JavaScript
手摸手教你,从0到1开发一个Chrome浏览器插件
开发 Chrome 插件既有趣又具成就感。本教程将引导你从零开始,逐步创建一个简单的 Chrome 插件。首先了解 Chrome 插件是可增强浏览器功能的小程序。以一个基础示例开始,你将学习如何设置开发环境,包括安装 Chrome 和准备文本编辑器,并掌握 HTML、CSS 和 JavaScript 的基础知识。接着,我们将构建插件的基本结构,涉及 `manifest.json` 配置文件、`background.js` 后台脚本、`popup.html` 用户界面以及 `style.css` 样式表。
56 8
|
5天前
|
Web App开发
Chrome浏览器导出HTTPS证书
Chrome浏览器导出HTTPS证书
12 0
Chrome浏览器导出HTTPS证书
|
29天前
|
Web App开发 JavaScript 前端开发
Chrome插件实现问题之最新的 Chrome 浏览器架构有什么新的改变吗
Chrome插件实现问题之最新的 Chrome 浏览器架构有什么新的改变吗
|
29天前
|
JavaScript 前端开发 Web App开发
Chrome插件实现问题之单进程浏览器的不稳定主要体现在什么地方
Chrome插件实现问题之单进程浏览器的不稳定主要体现在什么地方
|
29天前
|
Web App开发 前端开发 JavaScript
Chrome插件实现问题之用户在浏览器中输入URL后,浏览器进程会进行什么操作
Chrome插件实现问题之用户在浏览器中输入URL后,浏览器进程会进行什么操作

热门文章

最新文章