堪称全网最详细的前端面试八股文,面试必备(附答案)

面试官翻开你的简历时,已经在心里问出了这三个问题,而大多数人倒在了第二个。

作为面试过近200名前端工程师的技术负责人,我见过太多候选人带着漂亮的简历走进会议室——Vue/React全家桶倒背如流、项目经历写得满满当当、算法题刷了成百上千道。

可当我开始问「为什么选择这个架构方案」「如果让你重新设计这个组件会怎么做」「这个技术决策背后的业务逻辑是什么」 时,超过60% 的候选人都会出现短暂的沉默。

前端面试早已不是「背API就能过」的时代了。今天的面试官想看到的,是框架背后的设计思维、是业务场景下的技术决策逻辑、是代码之外的工程化素养

这篇文章将彻底拆解前端面试中的核心八股文,但不止于标准答案——我会带你还原每一个技术问题背后的真实考察意图,并附上能让面试官眼前一亮的深度解析

全文目录:

1.JavaScript面试题(323题)
2.CSS面试题(61题)
3.HTML面试题(57题)
4.React面试题(83题)
5.Vue面试题(80题)
5.算法面试题(19题)
7.计算机网络(71题)
8.Node.js面试题(27题)
9. TypeScript面试题(46题)
10.性能优化面试题(25题)
11.前端安全面试题(21题)
12.小程序面试题(9题)
13.ES6面试题(32题)
14.编程题(50题)
15.设计模式面试题(7题)
16.工程化面试题(34题)

先贴一下GitHub: https://github.com/encode-studio-fe-coder/natural_traffic/wiki/scan_material3

一、JavaScript(323题)

1.不会冒泡的事件有哪些?

2.mouseEnter 和 mouseOver 有什么区别?

3.MessageChannel 是什么,有什么使用场景?

4. async、await 实现原理

5.Proxy 能够监听到对象中的对象的引用吗?

6.如何让 var [a, b]= {a: 1,b:2}解构赋值成功?

7.下面代码会输出什么?

8.描述下列代码的执行结果

9.什么是作用域链?

10.bind、call、apply 有什么区别?如何实现-个bind?

二、CSS(61题)

1. css 中的 animation、transition、 transform 有什么区别?

2.怎么做移动端的样式适配?

3.相邻的两个inline-block节点为什么会出现间隔,该如何解决?

4. grid网格布局是什么?

5.CSS3新增了哪些特性?

6.怎么使用 CSS3 实现动画?

7.怎么理解回流跟重绘?什么场景下会触发?

8.什么是响应式设计?响应式设计的吗?基本原理是什么?如何进行实现?

9.如果使用CSS提高页面性能?

10.如何实现单行/多行文本溢出的省略样式?

三、HTML(57题)

1. 什么是 DOM 和 BOM?

2.简单描述从输入网址到页面显示的过程

3.一台设备的dpr,是否是可变的?

4.前端该如何选择图片的格式?

5.前端跨页面通信,你知道哪些方法?

6.说说你对 Dom 树的理解

7.行内元素有哪些?块级元素有哪些? 空(void)元素有那些?

8.html和css中的图片加载与渲染规则是什么样的?

9.title与h1的区别、b与strong的区别、i与em的区别?

10.script 标签为什么建议放在 body 标签的底部(defer、async)

四、React(83题)

1.下面代码中,点击“+3"按钮后,age 的值是什么?

2.React Portals 有什么用?

3.react 和 react-dom 是什么关系?

4. React 中为什么不直接使用 requestIdleCallback?

5.为什么 react 需要 fiber 架构,而 Vue 却不需要?

6.子组件是一个 Portal,发生点击事件能冒泡到父组件吗?

8.说说React render方法的原理?在什么时候会被触发?

9.说说React事件和原生事件的执行顺序

10.说说对受控组件和非受控组件的理解,以及应用场景?

五、Vue(80题)

1. Vue 有了数据响应式,为何还要 dif ?

2.vue3 为什么不需要时间分片?

3.vue3 为什么要引入 Composition API ?

4.谈谈 Vue 事件机制,并手写$on、$off、$emit、$once

5.computed 计算值为什么还可以依赖另外-个 computed 计算值?

6.说-下 vm.$set 原理

7. 怎么在 Wue 中定义全局方法?

8.Vue 中父组件怎么监听到子组件的生命周期?

10.说说 vue3 中的响应式设计原理

六、算法(19题)

1.最大的钻石

2.举例说明你对尾递归的理解,以及有哪些应用场景

3.去除字符串中出现次数最少的字符,不改变原字符串的顺序。

4.请手写“快速排序”

5.洗牌算法

6.什么是尾调用优化和尾递归?

7.合并K个升序链表

8.什么是时间复杂度?

9.请手写“基数排序”

10.请手写"桶排序"

七、计算机网络(71题)

1.简单描述从输入网址到页面显示的过程

2.说说WebSocket和HTTP的区别

3.说说 https 的握手过程

4.HTTP2中,多路复用的原理是什么?

5.说说你对"三次握手"、“四次挥手”的理解

6.为什么推荐将静态资源放到cdn上?

7.什么是DNS劫持?

8.TLS 1.3 做了哪些改进?

9.TLS1.2 握手的过程是怎样的?

10.HTTP 报文结构是怎样的?

八、Node.js(27题)

1.common.js和es6中模块引入的区别?

2.为什么Node在使用es module时必须加上文件扩展名?

3.浏览器和 Node 中的事件循环有什么区别?

4.Node性能如何进行监控以及优化?

5.如果让你来设计一个分页功能,你会怎么设计?前后端如何交互?

6.如何实现文件上传?说说你的思路

7.如何实现iwt鉴权机制?说说你的思路

8.说说对中间件概念的理解,如何封装 node 中间件?

9.说说 Node 文件査找的优先级以及 Require 方法的文件查找策略?

10.说说对Nodejs中的事件循环机制理解?

九、 TypeScript(46题)

1.说说对 TypeScript 中命名空间与模块的理解?区别?

2.说说你对 typescript 的理解?与 javascript 的区别?

3.Typescript中泛型是什么?

4.TypeScript中有哪些声明变量的方式?

5.什么是Typescript的方法重载?

6.请实现下面的 sleep 方法

7. typescript 中的 is 关键字有什么用?

8.TypeScript支持的访问修饰符有哪些?

9.请实现下面的 myMap 方法

10.请实现下面的 treePath 方法

十、性能优化(25题)

1.script标签放在header里和放在body底部里有什么区别?

2.前端性能优化指标有哪些?怎么进行性能检测?

3.SPA(单页应用)首屏加载速度慢怎么解决?

4.如果使用CSS提高贞面性能?

5.怎么进行站点内的图片性能优化?

6.虚拟DOM一定更快吗?

7.有些框架不用虚拟dom,但是他们的性能也不错是为什么?

8.如果某个页面有几百个函数需要执行,可以怎么优化页面的性能?

9.讲一下png8、png16、png32的区别,并简单讲讲 png 的压缩原理

10.React.memo()和 useMemo()的用法是什么,有哪些区别?

十一、前端安全(21题)

1.说说你对 XSS的了解

2.web常见的攻击方式有哪些,以及如何进行防御?

3.说说你对前端鉴权的理解

4.如何禁止别人调试自己的前端代码?

5.CSP(Content Security Policy)可以解决什么问题?

6.前端怎么实现跨域请求?

7. HTTPS 有哪些优点?

8.webSocket 有哪些安全问题,应该如何应对?

9.什么是点击劫持?如何防范点击劫持?

10.什么是 Samesite Cookie 属性?

十二、小程序(9题)

1.说说微信小程序的架构?

2.为什么小程序里拿不到dom相关的api?

3.小程序的双线程分别做的什么事情?

4.简述微信小程序原理?

5.微信小程序的优劣势?

6.小程序页面间有哪些传递数据的方法?

7.微信小程序bindtap 和 catchtap 区别?

8.小程序 WXSS 与 CSS 的区别?

9.简述一下微信小程序的主要文件有哪些?

十三、ES6(32题)

1.common.js和es6中模块引入的区别?

2.Map 和 Set 的用法以及区别

3.es5 中的类和es6中的cass有什么区别?

4.你是怎么理解ES6中 Decorator 的?使用场景有哪些?

5.你是怎么理解ES6中Module的?使用场景有哪些?

6.你是怎么理解ES6中Proxy的?使用场景有哪些?

7.怎么理解ES6中 Generator的?使用场景有哪些?

8.你是怎么理解ES6中 Promise的?使用场景有哪些?

9.ES6中新增的Set、Map两种数据结构怎么理解?

10.ES6中函数新增了哪些扩展?

十四、编程题(50题)

1.使用Promise实现红绿灯交替重复亮

2.bind、call、apply 有什么区别?如何实现-个bind?

4.说说new操作符具体干了什么?

5.如何实现上拉加载,下拉刷新?

6.大文件怎么实现断点续传?

7.什么是防抖和节流,以及如何编码实现?

8.说说ajax的原理,以及如何实现?

9.深拷贝浅拷贝有什么区别?怎么实现深拷贝?

10.用js实现二叉树的定义和基本操作

十五、设计模式(7题)

1.观察者模式和发布订阅模式分别是什么?有什么区别?

2.开发的过程中你用到过哪些设计模式?

3.设计模式分类

4. 什么是 MVVM? 比之 MVC 有什么区别?什么又是 MVP ?

5.单例模式

6.设计模式的六大原则

7. 工厂模式

十六、前端工程化(34题)

1. package.json 文件中的 devDependencies 和 dependencies 对象有什么区别?

2.webpack 5 的主要升级点有哪些?

3.说下vite的原理

4.与webpack类似的工具还有哪些?区别?

5.说说如何借助webpack来优化前端性能?

6.说说webpack proxy工作原理?为什么能解决跨域?

7.说说webpack的热更新是如何做到的?原理是什么?

8.面试官:说说Loader和Plugin的区别?编写Loader,Plugin的思路?

9.说说webpack中常见的Plugin?解决了什么问题?

10.说说webpack中常见的Loader?解决了什么问题?

注:文中的前端八股文面试汇总PDF已经打包完毕,希望对大家有帮助: https://github.com/encode-studio-fe-coder/natural_traffic/wiki/scan_material3

Read more

【详细精选】前端面试题(2026精选附详细解答)包含10w数据展示优化、前端核心

【详细精选】前端面试题(2026精选附详细答案)包含10w数据展示优化、前端核心 * 前端面试题详细解答 * 1. ES6新特性详解(重要10个) * 核心特性 * 其他重要特性 * 2. 什么是跨域 * 同源策略 * 跨域解决方案 * 1.CORS(跨域资源共享) * 2.JSONP * 3. 代理服务器 * 4. WebSocket * 5. Nginx反向代理 * 3. 监听数组变化 * Vue2的实现原理 * Vue3的实现原理 * 4. v-if vs v-show * 原理对比 * 差异对比表 * 源码分析 * 5. 网页加载优化 * 性能指标(Core Web Vitals) * 优化策略 * 1. 代码优化 * 2. 资源优化 * 3. 缓存策略

By Ne0inhk
用Selenium实现一个免费的Web搜索API服务

用Selenium实现一个免费的Web搜索API服务

用Selenium实现一个免费的Web搜索API服务 * 一、引言:为什么我们需要这个工具? * 二、核心思路:模拟人类,获取数据 * 三、分步实现 * 1、搭建搜索服务端(`server.py`) * 2、创建客户端(`client.py`) * 四、如何运行? * 1. 启动服务端 * 2. 测试客户端 * 五、实际应用:集成到AI智能体 * 示例:在LangChain中使用 * 五、结语 一、引言:为什么我们需要这个工具? 在AI智能体(Agents)飞速发展的今天,让它们能够“联网思考”已成为刚需。想象一下,你的AI助手不仅能回答训练数据中的问题,还能实时获取最新的新闻、股价、科研成果——这就像给盲人恢复了视力。 然而,现实很骨感:主流的搜索API服务(如Google

By Ne0inhk
⸢ 伍-Ⅱ⸥ ⤳ 默认安全治理实践:水平越权检测 & 前端安全防控

⸢ 伍-Ⅱ⸥ ⤳ 默认安全治理实践:水平越权检测 & 前端安全防控

👍点「赞」📌收「藏」👀关「注」💬评「论」         在金融科技深度融合的背景下,信息安全已从单纯的技术攻防扩展至架构、合规、流程与创新的系统工程。作为一名从业十多年的老兵,将系统阐述数字银行安全体系的建设路径与方法论,旨在提出一套可落地、系统化、前瞻性的新一代安全架构。 序号主题内容简述1安全架构概述全局安全架构设计,描述基础框架。👉2默认安全标准化安全策略,针对已知风险的标准化防控(如基线配置、补丁管理)。3可信纵深防御多层防御体系,应对未知威胁与高级攻击(如APT攻击、零日漏洞)。4威胁感知与响应 实时监测、分析威胁,快速处置安全事件,优化第二、三部分策略。 5实战检验通过红蓝对抗演练验证防御体系有效性,提升安全水位。6安全数智化运用数据化、自动化、智能化(如AI)提升安全运营(各部分)效率。 目录 5 默认安全治理应用实践 5.2 水平越权漏洞检测 1.水平越权检测的痛点

By Ne0inhk
离开舒适区之后:从三年前端到 CS 硕士——我在韩国亚大读研的得失

离开舒适区之后:从三年前端到 CS 硕士——我在韩国亚大读研的得失

过去一年多,我做了一个挺重要的决定:辞职,去韩国留学读研。 这段时间我几乎没怎么学习新的前端内容,但也没有停下来。我在韩国亚洲大学完成了计算机科学与技术(大数据)硕士的学习,在高强度的节奏里重新建立了自己的方法,也因为持续写博客获得了一些机会,担任本科 Web 实训课讲师。现在这段留学告一段落,我也准备重新回到前端领域,把这段经历当作一份额外的积累带回去。这篇复盘主要是想把这一路的收获、疲惫和一些值得记住的瞬间记录下来,留给未来的自己,也分享给路过的你。 文章目录 * 1、写在前面:我为什么会从前端转去读研 * 2、留学生活的关键词:卷、AI、被看见以及校庆的“放开玩” * 3、我的“结果卡片” * 4、得:这一年半我真正收获的东西 * 5、失:我付出的代价 * 6、期末周:我经历过的“高强度交付周” * 7、前端三年经验,如何在读研里“迁移复用” * 8、我在韩国的学习系统:

By Ne0inhk