news 2026/4/23 10:16:08

浏览器原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
浏览器原理

浏览器原理

一、 宏观视角:Chrome 多进程架构

现在的浏览器更像是一个分布式操作系统,而非简单的应用程序。

1. 四大核心进程

  • Browser Process (主进程)
    • 职责:负责 UI(地址栏、书签)、协调子进程、管理存储(Cookie/Storage)。
    • 地位:整个浏览器的总指挥。
  • Renderer Process (渲染进程)
    • 职责:解析 HTML/CSS/JS,将网页转化为图像。
    • 机制沙箱隔离,通常一页一进程(Site Isolation 策略保证跨域隔离)。
  • GPU Process
    • 职责:负责页面最终的绘制与合成,处理 WebGL、CSS3 3D 变换。
  • Network Service
    • 职责:独立负责网络资源加载,提升安全性和稳定性(防崩溃)。

2. 为什么是多进程?

  • 稳定性:一个 Tab 崩了,不会导致整个浏览器崩。
  • 安全性:渲染进程运行在沙箱中,限制了读写系统文件的权限。
  • 流畅性:JS 阻塞渲染进程时,不会影响 Browser 进程的 UI 响应(如切换 Tab)。

二、 导航全流程:从 URL 到页面展示

当你在地址栏按下回车:

  1. 处理输入:Browser 进程判断是 URL 还是搜索查询。
  2. 网络请求:Network Service 发起 DNS -> TCP -> TLS -> HTTP 请求。
    • 注:Service Worker 可在此阶段拦截请求,直接返回缓存。
  3. 响应读取:检查 MIME Type。如果是 HTML,通知 Browser 进程。
  4. 准备渲染进程:Browser 进程启动或复用一个 Renderer 进程。
  5. 提交导航
    • 关键点:Renderer 进程接收数据流。此时旧页面卸载,新页面白屏,Loading 圈开始转动。

三、 渲染流水线

这是前端性能优化的核心战场。

1. 解析 (Parsing)

  • HTML ➝ DOM 树:构建文档结构。
  • CSS ➝ CSSOM 树:计算具体样式。

2. 布局 (Layout/Reflow)

  • DOM + CSSOM ➝ Layout Tree (布局树)
  • 规则
    • display: none不在布局树中。
    • visibility: hidden布局树中(占位)。
    • 布局树节点包含了元素的几何信息 (x, y, width, height)

3. 分层 (Layering)

  • 浏览器将页面拆分为多个图层 (Layers)以实现独立光栅化。
  • 触发条件will-change,transform: translateZ,opacity,<video>,z-index上下文等。
  • 目的:避免牵一发而动全身,减少重绘区域。

4. 绘制

  • 生成绘制列表 (Paint Records)。注意,这只是一堆绘制指令(“画个红圈”),并没有真正填充像素。

5. 合成 —— 性能之源

  • 角色:合成线程 (Compositor Thread) 与 GPU 配合。
  • 流程
    1. 分块:将图层切分成小块。
    2. 光栅化:将图块转换为位图 (Bitmap)(通常由 GPU 完成)。
    3. 合成:GPU 将所有位图合成最终屏幕图像。

总结:性能优化三大法宝

  • Reflow (重排):修改了几何属性(宽/高)。触发Layout -> Paint -> Composite最贵
  • Repaint (重绘):修改了颜色/背景。触发Paint -> Composite次之
  • Composite (合成):修改transformopacity只触发 Composite
    • 原理:不占用主线程,直接在合成线程操作图块。即使 JS 卡死,动画依然流畅。

四、 JavaScript 运行机制

1. 内存管理 (V8)

  • :存储执行上下文、基本类型。
  • :存储对象。GC 采用分代回收(新生代 Scavenge 算法 + 老生代 标记-清除-整理)。

2. 事件循环 (Event Loop)

浏览器的循环机制如下(与 Node.js 略有不同):

  1. 执行栈 (Stack):同步代码执行完毕。
  2. 微任务:清空队列!(Promise.then,MutationObserver).
    • Microtasks 优先级极高,插队执行,直到队列为空。
  3. 渲染时机:判断是否需要更新屏幕(通常 16.6ms 一次)。
    • 如果有,执行requestAnimationFrame-> Style -> Layout -> Paint。
  4. 宏任务:取一个任务执行。(setTimeout,setInterval, I/O, UI Event).
  5. 回到第一步。

启示

  1. 动画选 CSS:尽量用transformopacity,避开 layout 属性(top/left/width)。
  2. 避免强制同步布局:不要在修改样式后紧接着读取offsetHeight/scrollTop等属性。
  3. 减少主线程阻塞:复杂的 JS 计算会延迟渲染和交互,考虑使用Web Worker
  4. 利用空闲时间:低优先级的逻辑可以使用requestIdleCallback
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 16:51:32

Docker学习笔记—day012

Docker学习笔记—day012&#xff08;容器化编排&#xff09; 文章目录一、Docker-Compose1.1、docker-compose是什么1.2、docker-compose能干什么1.3、docker-compose下载1.4、docker-compose核心概念1.5、docker-compose使用的三个步骤1.6、docker-compose使用的三个步骤二、D…

作者头像 李华
网站建设 2026/4/17 2:00:15

ansible事实详解

Ansible 事实是 Ansible 在执行任务前&#xff0c;自动从受控节点收集的系统信息集合&#xff0c;这些信息会以变量形式存储&#xff0c;能直接用于区分不同节点的配置逻辑&#xff0c;实现自动化任务的差异化执行。1. 核心收集的信息类型• 基础主机信息&#xff1a;包含主机…

作者头像 李华
网站建设 2026/4/22 21:26:47

机器学习资源合集

Python数据分析与机器学习实战课程 文件大小: 15.6GB内容特色: 15.6GB Python数据机器学习全流程项目源码适用人群: 想转岗AI/数据岗的大学生与程序员核心价值: 代码即用&#xff0c;快速复现Kaggle级建模与调优下载链接: https://pan.quark.cn/s/e349f01253fa 【数据技术课堂…

作者头像 李华
网站建设 2026/4/18 6:47:45

朴易天下:铁板神数的起源及流派介绍

第二十二章&#xff1a;铁板神数铁版神数是中国古代命理术数之一&#xff0c;相传由宋朝时的邵雍&#xff08;邵康节&#xff09;所发明&#xff0c;这个说法没有确实的证据。铁板神数兴盛于清代。相传铁板神数大师仅靠算盘拨算几下&#xff0c;以查条文形式批命&#xff0c;便…

作者头像 李华
网站建设 2026/4/22 8:33:57

COMSOL助力煤层注气热力流THM耦合下增强甲烷开采探索

一、COMSOL实现煤层注气热力流THM耦合下增强甲烷开采。 本案例采用热力流三场耦合&#xff0c;分析煤层注入CO2增强甲烷开采效果&#xff0c;涉及热-流-固数学模型、多气相介质作用&#xff0c;全部为PDE模块。 二、可以出煤层温度、瓦斯含量、渗透率等许多云图及数据&#xff…

作者头像 李华
网站建设 2026/4/8 7:46:55

实战指南:企业如何构建GEO与SEO融合的全新营销体系

面对2025年高达67.8%的市场增速&#xff0c;GEO&#xff08;生成式引擎优化&#xff09;已从一个前沿概念&#xff0c;转变为国内市场规模达480亿元的核心商业基础设施。当AI直接为用户提供答案成为新常态&#xff0c;企业面临的核心挑战已不再是“做不做”&#xff0c;而是“如…

作者头像 李华