面试官问输入url到页面渲染,你该如何回答?(详版)

本文详细介绍了浏览器从输入URL到页面完全加载的过程,包括DNS解析、TCP连接建立、HTTP请求与响应、资源缓存策略及HTML文档解析等多个环节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.在浏览器地址栏输入URL

2.浏览器查看缓存,如果请求资源在缓存中并且新鲜,跳转到转码步骤

        (1)如果资源未缓存,发起新请求

        (2)如果已缓存,检验是否足够新鲜,足够新鲜直接提供给客户端,否则与服务器进行验证。

        (3)检验新鲜通常有两个HTTP头进行控制Expires和Cache-Control:

                HTTP1.0提供Expires,值为一个绝对时间表示缓存新鲜日期
                HTTP1.1增加了Cache-Control: max-age=,值为以秒为单位的最大新鲜时间

3.浏览器解析URL获取协议,主机,端口,path

4.浏览器组装一个HTTP(GET)请求报文

5.浏览器获取主机ip地址,过程如下:

        浏览器缓存
        本机缓存
        hosts文件
        路由器缓存
        ISP DNS缓存

        DNS递归查询(可能存在负载均衡导致每次IP不一样)

6. 打开一个socket与目标IP地址,端口建立TCP链接,三次握手如下:

        (1)客户端发送一个TCP的SYN=1,Seq=X的包到服务器端口

        (2)服务器发回SYN=1, ACK=X+1, Seq=Y的响应包

        (3)客户端发送ACK=Y+1, Seq=Z

7.TCP链接建立后发送HTTP请求

8.服务器接受请求并解析,将请求转发到服务程序,如虚拟主机使用HTTP Host头部判断请求的服务程序

9.服务器检查HTTP请求头是否包含缓存验证信息如果验证缓存新鲜,返回304等对应状态码

10.处理程序读取完整请求并准备HTTP响应,可能需要查询数据库等操作

11.服务器将响应报文通过TCP连接发送回浏览器

12.浏览器接收HTTP响应,然后根据情况选择关闭TCP连接或者保留重用,关闭TCP连接的四次握手如下:

        (1)主动方发送Fin=1, Ack=Z, Seq= X报文

        (2)主动方发送Fin=1, Ack=Z, Seq= X报文

        (3)被动方发送Fin=1, ACK=X, Seq=Y报文

        (4)主动方发送ACK=Y, Seq=X报文 

13.浏览器检查响应状态吗:是否为1XX,3XX, 4XX, 5XX,这些情况处理与2XX不同

14. 如果资源可缓存,进行缓存

15.对响应进行解码(例如gzip压缩)

16.根据资源类型决定如何处理(假设资源为HTML文档)

17. 解析HTML文档,构件DOM树,下载资源,构造CSSOM树,执行js脚本,这些操作没有严格的先后顺序,以下分别解释

18.构建DOM树:

        (1)Tokenizing:根据HTML规范将字符流解析为标记

        (2)Lexing:词法分析将标记转换为对象并定义属性和规则

        (3)DOM construction:根据HTML标记关系将对象组成DOM树

19.解析过程中遇到图片、样式表、js文件,启动下载

20.构建CSSOM树:

        (1)Tokenizing:字符流转换为标记流

        (2)Node:根据标记创建节点

        (3)CSSOM:节点创建CSSOM树

21.根据DOM树和CSSOM树构建渲染树

        (1)从DOM树的根节点遍历所有可见节点,不可见节点包括:1)script,meta这样本身不可见的标签。2)被css隐藏的节点,如display: none

        (2)对每一个可见节点,找到恰当的CSSOM规则并应用

        (3)发布可视节点的内容和计算样式

22.js解析如下:

        (1) 浏览器创建Document对象并解析HTML,将解析到的元素和文本节点添加到文档中,此时document.readystate为loading

        (2)HTML解析器遇到没有async和defer的script时,将他们添加到文档中,然后执行行内或外部脚本。这些脚本会同步执行,并且在脚本下载和执行时解析器会暂停。这样就可以用document.write()把文本插入到输入流中。同步脚本经常简单定义函数和注册事件处理程序,他们可以遍历和操作script和他们之前的文档内容

        (3)当解析器遇到设置了async属性的script时,开始下载脚本并继续解析文档。脚本会在它下载完成后尽快执行,但是解析器不会停下来等它下载。异步脚本禁止使用document.write(),它们可以访问自己script和之前的文档元素

        (4)当文档完成解析,document.readState变成interactive

        (5)所有defer脚本会按照在文档出现的顺序执行,延迟脚本能访问完整文档树,禁止使用document.write()

        (6) 浏览器在Document对象上触发DOMContentLoaded事件

        (7)此时文档完全解析完成,浏览器可能还在等待如图片等内容加载,等这些内容完成载入并且所有异步脚本完成载入和执行,document.readState变为complete,window触发load事件

23.显示页面(HTML解析过程中会逐步显示页面)

<think>好的,用户让我列举一些前端面试题。我需要先理清用户的需求。可能他们正在准备面试,需要了解常见的题目来复习。用户可能是刚毕业的学生或者想转行前端的人,对面试内容不太熟悉,需要指导。 首先,我得确定前端面试通常涵盖哪些方面。一般来说,基础部分包括HTML、CSS、JavaScript,然后是框架如React、Vue,还有性能优化、网络知识、工程化、手写代码等。 接下来,我需要分门别类地整理题。比如,把HTML和CSS的题放在一起,然后是JavaScript的核心概念,接着是框架相关的题。性能优化和网络协议也是重点,尤其是HTTP、浏览器原理这些。工程化可能涉及Webpack、Babel,还有代码管理工具如Git。另外,手写代码题和算法题也是常考的,比如防抖、节流、深拷贝等。 需要注意题要有一定的深度,不能太表面。例如,闭包、原型链、事件循环这些JS核心概念必须细。框架部分要比较React和Vue的异同,生命周期钩子,状态管理等等。性能优化方面,可能需要提到懒加载、减少重排重绘、Web Workers等。 还要考虑面试官可能会追题,比如从输入URL页面加载的过程,跨域解决方案,安全相关的题如XSS和CSRF。这些都需要涵盖进去。 另外,用户可能需要题背后的原理,而不仅仅是表面的答案。例如,Virtual DOM的原理,React Fiber架构,这些都需要解释清楚。同时,手写代码题要给出例子,比如实现Promise、柯里化函数等。 最后,要确保内容结构清晰,分点列出,每个类别下有几个典型题。这样用户复习起来有条理,容易掌握重点。可能还需要提醒用户不仅要记住答案,还要理解原理,并能结合实际例子说明。</think>以下是一些前端开发岗位面试中高频出现的题,按技术模块分类整理,供针对性准备: --- ### 一、HTML & CSS 基础 1. **盒模型** - 标准盒模型 vs IE盒模型的区别?如何通过`box-sizing`控制? - 如何实现一个元素水平垂直居中? 2. **布局** - Flex布局中`justify-content`和`align-items`的区别? - Grid布局如何定义行列?`fr`单位的含义是什么? 3. **响应式设计** - 如何通过媒体查询(`@media`)适配不同屏幕尺寸? - `rem`和`em`单位的区别及使用场景? --- ### 二、JavaScript 核心 1. **闭包与作用域** - 解释闭包的概念,并举例实际应用场景(如模块化、防抖节流)。 - 以下代码输出什么?为什么? ```javascript for (var i = 0; i < 5; i++) { setTimeout(() => console.log(i), 1000); } ``` 2. **原型与继承** - 如何实现原型链继承?`new`操作符内部做了什么? - `Object.create(null)`和`{}`的区别? 3. **异步编程** - Promise的三种状态及链式调用规则?如何实现`Promise.all`? - `async/await`与Promise的关系?如何处理错误? --- ### 三、框架相关(React/Vue) #### React 1. **核心机制** - Virtual DOM 的 diff 算法原理?React Fiber 解决了什么题? - 受控组件与非受控组件的区别? 2. **Hooks** - `useEffect`的依赖数组如何工作?如何模拟`componentDidMount`? - 为什么不能在条件语句中使用Hooks? #### Vue 1. **响应式原理** - Vue 2 的`Object.defineProperty`与 Vue 3 的`Proxy`有何优劣? - `computed`和`watch`的使用场景区别? --- ### 四、浏览器与网络 1. **渲染机制** - 浏览器从输入URL页面渲染的完整流程(涉及DNS、TCP、DOM树构建等)? - 什么是重排(Reflow)和重绘(Repaint)?如何优化? 2. **HTTP协议** - GET和POST请求的本质区别?HTTP缓存策略有哪些? - HTTPS握手过程?如何理解对称加密与非对称加密的结合? 3. **跨域题** - CORS机制的工作原理?如何通过JSONP实现跨域? --- ### 五、性能优化 1. 首屏加载速度优化方案(代码分割、懒加载、CDN加速等) 2. 如何通过Chrome DevTools分析性能瓶颈? 3. Web Workers的使用场景及限制? --- ### 六、工程化与工具 1. Webpack的Loader和Plugin区别?如何实现按需加载? 2. Babel的作用及核心原理(AST转换)? 3. Git工作流(如Rebase与Merge的区别)? --- ### 七、手写代码题 1. 实现防抖(Debounce)和节流(Throttle) 2. 深拷贝(Deep Clone)函数 3. 手写Promise(包含then链式调用) 4. 实现一个柯里化(Currying)函数 --- ### 八、综合设计题 1. 如何设计一个前端埋点监控系统? 2. 单页应用(SPA)与服务器端渲染(SSR)的优劣对比? 3. 前端安全防护(XSS、CSRF的原理及防御手段) --- #### 准备建议: 1. **理解原理**:避免死记硬背,重点掌握题背后的设计思想(如Virtual DOM的优化逻辑)。 2. **结合实际项目**:对简历中的项目技术细节要能清晰阐述(如“为什么选React而非Vue”)。 3. **代码实践**:手写代码题需反复练习,注意边界条件和代码健壮性。 建议结合具体岗位JD(Job Description)调整复习侧重点,例如大厂更关注算法和底层原理,中小厂可能侧重工程化经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值