当前位置: 首页 > news >正文

[特殊字符] 在浏览器地址栏输入 URL 后,页面是怎么一步步显示出来的?

这是一个前端面试 100% 会被问到的问题
但也是一个90% 的人答不完整的问题

你可能会说:

  • “DNS 解析
  • “请求 HTML”
  • “解析 DOM”
  • “渲染页面”

👉但如果继续追问:

  • CSS 为什么会阻塞渲染?
  • JS 为什么会卡住页面?

  • 回流和重绘
    到底差在哪?

  • 浏览器内核到底在干嘛?

很多人就开始“凭感觉回答了”。

这篇文章,我会用尽量通俗、不堆术语的方式,带你完整走一遍:

从你敲下回车,到页面真正出现在屏幕上,中间到底发生了什么?

一、先给结论:浏览器做了哪几件大事?

不讲细节,先给你一条完整主线👇

输入 URL → 页面展示,大致分 9 步:

  1. 解析 URL(域名 / IP)
  2. DNS 解析(域名 → IP)
  3. 向服务器请求 HTML(通常是 index.html)
  4. 解析 HTML,生成 DOM Tree
  5. 解析 CSS,生成 CSSOM Tree
  6. DOM + CSSOM → Render Tree
  7. Layout(计算位置和大小)
  8. Paint(绘制像素)
  9. Composite(图层合成,GPU 加速)

你现在只需要记住一句话:

浏览器做的事情,本质上就是:
把“代码”一步步变成“像素”。

后面我们逐个拆。

二、URL、域名、IP、DNS:浏览器是怎么找到服务器的?

1️⃣ IP 是什么?

一句话:

IP 地址 = 服务器在互联网上的门牌号

比如:
101.34.243.124

  • 公网 IP 在整个互联网中是唯一的
  • 只要你知道 IP,就能直接访问服务器

2️⃣ 那为什么还要域名?

因为 IP:

  • 难记
  • 不符合人类直觉

所以就有了:

  • google.com
  • baidu.com
  • juejin.cn

👉域名,本质上就是 IP 的“别名”

3️⃣ DNS 到底在干嘛?

DNS 只干一件事:

把「好记的域名」翻译成「真实的 IP 地址」

流程非常简单:

你输入 juejin.cn ↓ DNS 查询 ↓ 得到一个 IP ↓ 浏览器去这个 IP 对应的服务器请求资源

4️⃣ 公网 IP 和私有 IP 的区别

  • 公网 IP
    • 全网唯一
    • 能被外部访问
  • 私有 IP
    • 只在局域网内有效
    • 学校 / 公司 / 家庭常见

三、为什么浏览器一上来就请求 index.html?

你有没有想过一个问题:

我明明只输入了域名,
为什么服务器知道要返回 index.html?

原因很简单:

  • 浏览器访问服务器后
  • 默认请求一个入口文件
  • 这个文件几乎永远叫:index.html

所以你会发现:

  • Vue / React 项目最终都会打包出index.html
  • 服务器部署的,其实是一堆静态资源
  • HTML 是一切渲染的起点

四、浏览器内核到底是什么?为什么老爱被问?

很多人会说:

  • Chrome 是 Blink 内核
  • Firefox 是 Gecko
  • Safari 是 WebKit

内核到底是啥?

一句话解释:

浏览器内核 = 负责解析 HTML / CSS / JS,并把页面渲染出来的核心模块

也叫:
渲染引擎(Rendering Engine)

常见关系👇

浏览器内核
Chrome / Edge / OperaBlink
SafariWebKit
FirefoxGecko
IETrident(已淘汰)

五、浏览器是如何一步步把页面“画”出来的?

这一部分是整个问题的核心

1️⃣ 解析 HTML → DOM Tree

  • HTML 会被拆成一个个标签
  • 标签会被转换成节点
  • 最终形成一棵DOM 树

👉 DOM 树描述的是:页面的结构

2️⃣ 解析 CSS → CSSOM Tree

  • 遇到<link>,浏览器会下载 CSS
  • CSS 会被解析成CSSOM 树

⚠️重点来了:

CSS不会阻塞 DOM 的解析
会阻塞页面的渲染

3️⃣ DOM + CSSOM → Render Tree

  • Render Tree 只包含需要显示的节点
  • display: none的元素不会进入渲染树

👉 Render Tree 描述的是:页面真正要画什么

4️⃣ Layout:计算位置和大小

Layout 阶段,浏览器会计算:
每个元素在哪?多大?

5️⃣ Paint:真正开始画了

把布局结果,转换为屏幕上的像素

6️⃣ Composite:图层合成(性能关键)

  • 页面会被拆成多个图层
  • GPU 参与合成
  • transform / opacity / video 等会创建新图层

👉合理使用能提升性能,滥用会吃内存

六、回流 & 重绘:为什么页面会卡?

🔁 回流(Reflow)

一句话:

元素的位置或尺寸发生变化

常见触发场景:

  • 改 width / height
  • 改 position / display
  • DOM 结构变化
  • 读取布局信息(如getComputedStyle

⚠️回流一定会触发重绘

🎨 重绘(Repaint)

一句话:

只改外观,不改布局

例如:

  • color
  • background-color
  • box-shadow
  • opacity

👉 成本比回流小得多

🚀 常见性能优化建议

  • 一次性修改样式(class / cssText)
  • 减少 DOM 操作
  • 避免频繁读取布局信息
  • 合理使用position: absolute / fixed
  • 谨慎创建合成层

七、最后用一句话总结

浏览器渲染的本质就是:
HTML → DOM → CSSOM → Render Tree → Layout → Paint → Composite

如果你真正理解了这条链路:

  • 白屏问题
  • 页面卡顿
  • 动画掉帧
  • script / link 阻塞
  • 回流 & 重绘优化

都会变得非常清晰

http://www.jsqmd.com/news/303776/

相关文章:

  • 动力电池点焊工艺解析
  • 【网络安全】红蓝对抗|备战大型攻防演练,这一篇就够了_红蓝对抗演练方案
  • 2026年重庆职业高中综合实力排行榜 择校指南与各类需求全景解析
  • 永辉超市卡合规回收的平台怎么选,四大误区揭秘
  • 2026一体化污水处理设备优质公司推荐
  • 2026英语雅思零基础培训辅导机构推荐榜单 核心解析 助力家长精准匹配适配零基础辅导机构
  • 孤能子视角:文心AI点评朝代分析系列
  • 2025年不容错过的烧菜火锅店,附近这6家实力上榜!社区火锅/特色美食/烧菜火锅/火锅/美食,烧菜火锅品牌排行
  • 孤能子视角:“心理学“
  • 黑客技术之黑客常见10大攻击技术,你知道几个?_黑客一般采用哪些网络攻击技术
  • 孤能子视角:“精神分析“
  • 2026最全网络安全工程师面试题(附答案),金九银十找工作必看!
  • 计算机毕业设计springboot基于Android的电动汽车电桩管理平台 Android端SpringBoot架构的新能源汽车智慧充电服务平台 基于SpringBoot与Android的电动汽车
  • 计算机毕业设计springboot大学校园心理咨询平台 基于 SpringBoot 的高校学生心理支持云平台 SpringBoot+Vue 校园心理健康服务互动系统
  • 播客人必看指南:2026年适合播客的麦克风品牌推荐
  • Kali Linux 无线网络攻防教学实验(从虚拟机安装到抓取WIFI握手包)
  • cesium 2.5D效果
  • 2026 英语雅思培训课程口碑推荐排行榜,综合课程数据与学员真实评价的避坑指南
  • 2026英语封闭雅思培训班辅导机构排行榜+核心解析 助力家长为孩子挑选适配的封闭备考优质机构
  • 2026年ELISA试剂盒优选指南,通蔚生物产品受关注,通蔚生物/小鼠ELISA,ELISA试剂盒直销厂家推荐
  • 盘点当前应用广泛的ELISA试剂盒品牌与特点,sod试剂盒/IL-6试剂盒,ELISA试剂盒实力厂家有哪些
  • 2026年NMN年货节哪个牌子好,十大NMN品牌实力榜,看完送礼不踩雷
  • 沃尔玛礼品卡1分钟合规回收操作流程与注意事项详解
  • 2026英语封闭雅思培训班辅导机构推荐榜单 核心解析 助力家长精准匹配适配封闭辅导机构
  • 深度剖析2025年国内外CRM排名,探寻行业佼佼者
  • 计算机Java毕设实战-基于微信小程序+物联网技术的宠物定位与监控系统设计与实现基于物联网技术的宠物定位与监控系统设计小程序【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • OpenAI将收集开发者反馈:新一代工具或将更贴近工程实际
  • clawdbot 上手指南:5 分钟跑通第一个 Bot
  • 2026实测 出国英语雅思培训机构综合实力TOP5口碑榜单推荐,从课程到服务的全面对比
  • 2026英语雅思口语培训辅导机构排行榜+核心解析 家长择校实用指南 帮孩子精准匹配口语备考全阶段适配方案