输入 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. 重排、重绘、合成开销

重排 > 重绘 > 合成

相关推荐
ZzT5 小时前
公司用 AI 筛简历,他写了个 AI 帮你挑公司
面试·aigc·ai编程
PBitW6 小时前
GPT训练我的第四天,被打惨了!!!😭😭😭
前端·javascript·面试
云技纵横10 小时前
@Transactional 到底要不要加 rollbackFor?一次数据不一致事故讲清楚
后端·面试
Moment10 小时前
牛逼,NextJs 从 16.3 开始全面拥抱 Agent Native 🥰🥰🥰
前端·后端·面试
胡萝卜术11 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
胡萝卜术11 小时前
从暴力到Z字形消元:力扣240「搜索二维矩阵II」的降维打击之路
前端·javascript·面试
洛卡卡了1 天前
我们在用 AI 写代码时,为什么建议要好好维护 AGENTS.md 呢?
面试·agent·claude
PBitW1 天前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试
自由路飞1 天前
RAG 混合检索深挖:BM25 和向量分数为什么不能直接相加?
面试
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试