输入 URL 到页面展示速记版

输入 URL 到页面展示(结合浏览器多进程完整版面试口述版)

顺序 + 进程分工梳理,直接背诵,逻辑清晰、考点全覆盖。


整体流程(分 7 大步,标注对应进程)

1. 地址栏输入 URL,回车(浏览器主进程)

  1. 主进程判断输入内容是搜索词 还是网址
  2. 进行 DNS 缓存查询,没有则发起域名解析
  3. 主进程通过 IPC 通信 ,把网络请求任务交给网络进程

2. 网络请求阶段(网络进程)

  1. DNS 解析:域名 → IP 地址
  2. 建立 TCP 连接(三次握手),HTTPS 额外进行 TLS 加密协商
  3. 发送 HTTP 请求(请求行、请求头、请求体)
  4. 接收服务端响应:状态码、响应头、响应体(HTML 文档)
  5. 关闭/复用 TCP 连接
  6. 将 HTML 响应数据,通过 IPC 传回渲染进程

补充 :图片、JS、CSS 等后续静态资源,依然由网络进程统一请求


3. 解析 HTML,构建 DOM 树(渲染进程-主线程)

  1. 逐行解析 HTML,生成 DOM 树
  2. 解析过程中遇到:
    • 同步 JS阻塞 HTML 解析、阻塞渲染,主线程暂停,先执行 JS
    • <link> 外链 CSS:发起请求(网络进程),阻塞渲染,不阻塞 HTML 解析
    • <img>/<video>:异步发起请求,不阻塞 HTML 与首次渲染

4. 解析 CSS,构建 CSSOM 树(渲染进程-主线程)

解析所有 CSS,生成 CSSOM 样式规则树


5. 生成渲染树 Render Tree(渲染进程-主线程)

DOM + CSSOM 合并,只包含需要显示的节点


6. 布局 Layout + 绘制 Paint(渲染进程-主线程)

  1. 布局(回流):计算每个节点精确位置、大小
  2. 绘制(重绘):按样式把节点画成像素图层

7. 图层合成 Composite(渲染进程-合成线程 + GPU 进程)

  1. 合成线程将页面分层,分别生成图层
  2. 交由 GPU 进程 进行硬件加速合成、最终显示到屏幕
  3. 滚动、动画一般只走合成层,性能最高

精简背诵版(面试直接说,1 分钟讲完)

在浏览器主进程 中输入网址,主进程将请求转发给网络进程 ;网络进程完成 DNS 解析、TCP 连接、HTTP 请求并拿到 HTML 资源,再交给渲染进程

渲染进程主线程依次解析 HTML、CSS,构建 DOM、CSSOM、渲染树,完成布局和绘制;最后由合成线程配合GPU 进程做图层合成,页面最终展示。

其中图片、视频等资源异步加载,不会阻塞首次渲染。


高频延伸考点(顺带记忆)

1. 谁阻塞首次渲染?

  • 阻塞:同步 JS、CSS
  • 不阻塞:图片、视频、异步 JS

2. 进程分工总结

进程 职责
主进程 窗口管理、任务调度
网络进程 全部网络请求、缓存、协议处理
渲染进程 解析、JS 执行、布局、绘制
GPU 进程 图层合成、硬件加速

3. 重排、重绘、合成开销

重排 > 重绘 > 合成

相关推荐
烬羽3 小时前
JS 单线程为什么不卡?一文吃透同步异步、Event Loop 和 Promise
javascript·面试
哈撒Ki4 小时前
快速入门vue3与常见面试题
前端·vue.js·面试
2301_800895104 小时前
线性代数保研面试复习
线性代数·面试·保研
白露与泡影5 小时前
2026秋招冲刺:1000道Java高频面试题(各大厂考点汇总)
java·开发语言·面试
Cosolar5 小时前
深入理解 LangChain Callback 机制:从入门到实战
人工智能·后端·面试
海梨花7 小时前
字节面试高频算法题
java·算法·面试·职场和发展
折哥的程序人生 · 物流技术专研7 小时前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
大头嗯呢7 小时前
从 ACL 到零信任:权限系统设计模式的演进之路
面试·架构
程序员二叉7 小时前
【JVM】类加载全过程&双亲委派机制深度解析
java·jvm·面试