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

前端八股文面经大全:携程前端一面(2026-04-17)·面经深度解析

前言大家好我是木斯佳。相信很多人都感受到了在AI浪潮的席卷之下前端领域的门槛在变高纯粹的“增删改查”岗位正在肉眼可见地减少。曾经热闹非凡的面经分享如今也沉寂了许多。但我们都知道市场的潮水退去留下的才是真正在踏实准备、努力沉淀的人。学习的需求从未消失只是变得更加务实和深入。这个专栏的初衷很简单拒绝过时的、流水线式的PDF引流贴专注于收集和整理当下最新、最真实的前端面试资料。我会在每一份面经和八股文的基础上尝试从面试官的角度去拆解问题背后的逻辑而不仅仅是提供一份静态的背诵答案。无论你是校招还是社招目标是中大厂还是新兴团队只要是真实发生、有价值的面试经历我都会在这个专栏里为你沉淀下来。专栏快速地址温馨提示市面上的面经鱼龙混杂甄别真伪、把握时效是我们对抗内卷最有效的武器。面经原文内容面试公司携程面试时间4月17日面试岗位前端暑期一面⏱️面试时长40分钟❓面试问题bfccss布局问题如何实现一个容器左边根据文字无限扩大右边不扩大只缩小flex布局float左边grow1auto右边flex0在引导下勉强做出数组的遍历方法如何实现数组乱序可以用randomfor遍历数组每次遍历用random生成一个随机数作为索引用这个索引代表的数和当前遍历的这个数交换重排重绘如何减少重排重绘只答了个transform闭包具体应用场景md这玩意有点忘了闭包可能引起的问题内存泄露引用的大对象没释放事件循环现在其实不局限于宏队列微队列了但一定要有微队列把这玩意说了react事件事件委托16之后的事件委托变化提了一嘴合成事件现在想想应该具体讲的AI相关为什么要有agent用户不能直接和大模型交互吗可以但有agent更方便讲了skill和mcp如何解决上下文膨胀agent要考虑哪些维度的问题来源牛客网绿糖滑稽木木有话说刷前先看携程这场一面是一份“基础AI”结合的面经。从BFC、CSS布局、数组乱序到重排重绘、事件循环、覆盖面很广 携程前端一面·深度解析面试整体画像维度特征面试风格基础考察型 AI前沿型 引导追问型难度评级⭐⭐⭐三星半布局题有细节AI概念较新考察重心CSS布局BFC/弹性布局、JS基础闭包/事件循环/数组、React事件机制、AI Agent特殊之处涉及Agent、MCP、Skill等较新的AI工程化概念逐题深度解析二、BFC块级格式化上下文回答思路BFC是独立的渲染区域内部元素与外部隔离。触发条件overflow: hidden/auto/scrollfloat不为noneposition: absolute/fixeddisplay: inline-block/flex/grid/table-celldisplay: flow-root解决的问题清除浮动父元素包裹浮动子元素防止margin重叠相邻块级元素上下margin合并自适应两栏布局左侧浮动右侧触发BFC三、CSS布局左边文字无限扩大右边只缩小题目理解左边容器根据文字内容自动撑开右边容器填满剩余空间当空间不足时右边缩小甚至溢出被裁剪左边保持原始宽度。解决方案/* 方案1Flex布局 */.container{display:flex;width:100%;}.left{flex:0 0 auto;/* 不放大不缩小根据内容确定宽度 */background:lightblue;}.right{flex:1;/* 占据剩余空间空间不足时缩小 */min-width:0;/* 允许缩小到0防止溢出 */background:lightcoral;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}/* 方案2浮动 overflow */.container{overflow:hidden;/* 触发BFC */}.left{float:left;background:lightblue;}.right{overflow:hidden;/* 触发BFC不环绕浮动元素 */background:lightcoral;}关键点flex: 0 0 autoflex-grow: 0; flex-shrink: 0; flex-basis: auto;min-width: 0允许flex子项缩小到小于内容宽度右边需要设置overflow: hidden或text-overflow: ellipsis处理溢出文本四、数组的遍历方法方法是否改变原数组是否有返回值能否中断forEach否undefined否map否新数组否filter否新数组否reduce否累积值否some否布尔值可返回true终止every否布尔值可返回false终止find否第一个匹配元素可找到即终止findIndex否索引可for循环可-可for...of可-可五、如何实现数组乱序Fisher-Yates洗牌算法用户描述的正确functionshuffle(arr){for(letiarr.length-1;i0;i--){constjMath.floor(Math.random()*(i1))[arr[i],arr[j]][arr[j],arr[i]]}returnarr}注意arr.sort(() Math.random() - 0.5)是不均匀的不推荐。六、重排Reflow与重绘Repaint维度重排Reflow重绘Repaint触发几何属性变化宽高、边距、位置视觉属性变化颜色、背景、可见性开销大影响后续元素小只影响自身必然性重排一定导致重绘重绘不一定导致重排触发重排的操作添加/删除DOM元素改变宽高、边距、位置改变窗口大小读取offsetHeight、getComputedStyle等强制同步重排七、如何减少重排重绘优化策略使用transform/opacity做动画只触发合成跳过重排重绘读写分离避免在循环中交替读写布局属性批量修改样式使用class或cssText一次性修改使用文档片段document.createDocumentFragment()批量插入脱离文档流用position: absolute使元素独立使用will-change提前告知浏览器元素会变化// ❌ 不好循环中交替读写for(leti0;i1000;i){constwidthdiv.offsetWidth// 读div.style.widthwidth1px// 写强制重排}// ✅ 好读写分离constwidthdiv.offsetWidth// 只读一次div.style.widthwidth1000px// 只写一次八、闭包及具体应用场景定义函数可以访问其外部作用域的变量即使外部函数已执行完毕。应用场景防抖/节流保存timer变量模块化封装私有变量事件监听循环中保存正确索引函数工厂根据参数生成特定功能的函数迭代器生成器函数// 模块化示例constcounter((){letcount0return{increment:()count,decrement:()--count,getCount:()count}})()九、闭包可能引起的问题主要问题内存泄漏原因闭包引用的外部变量不会被垃圾回收如果这些变量是大对象或DOM元素会造成内存占用。// 内存泄漏示例functionleak(){constlargeDatanewArray(1000000).fill(data)constelementdocument.getElementById(btn)element.onclick(){console.log(largeData.length)// 闭包引用largeData和element}}// largeData和element无法被回收即使btn被移除解决方案及时解除引用element.onclick null避免在闭包中引用不必要的大对象使用WeakMap/WeakSet存储弱引用十、事件循环回答思路用户提到“现在其实不局限于宏队列微队列了”说明对最新标准有了解。核心流程执行同步代码清空微任务队列Promise.then、MutationObserver执行一个宏任务setTimeout、I/O、UI渲染重复2-3注意HTML标准中事件循环每个“轮次”会执行多个宏任务不标准是一个宏任务后立即执行微任务队列。但不同任务源task source之间有优先级。用户提到的“不局限于宏队列微队列”实际上浏览器有多个任务队列定时器、I/O、用户交互等不同任务源的任务执行顺序有优先级但核心的“微任务优先于宏任务”原则不变。十一、React事件机制React事件系统核心合成事件SyntheticEvent跨浏览器统一的封装事件委托React 16及之前所有事件都委托到document上React 17变化事件委托从document改为root节点容器节点便于微前端和多版本共存事件流程React在根节点监听原生事件收集需要执行的事件回调构建合成事件对象按捕获→目标→冒泡顺序执行// 合成事件特点functionhandleClick(e){e.preventDefault()// 跨浏览器统一e.stopPropagation()// 事件池React 17已移除e.persist() 使事件异步可用}十二、为什么要有Agent回答思路Agent是能自主规划、调用工具、完成复杂任务的AI系统。为什么需要Agent工具调用大模型不能直接执行代码、搜索、发请求Agent负责调度工具任务规划复杂任务需要分解成多个步骤Agent管理执行顺序记忆管理Agent维护短期/长期记忆解决上下文窗口限制错误恢复工具调用失败时Agent可以尝试替代方案用户提到的Skill和MCPSkill预定义的能力单元封装特定任务的指令工具MCPModel Context Protocol标准化Agent与工具的交互协议十三、用户不能直接和大模型交互吗回答可以但Agent提供更好的体验和更强的能力。直接交互的局限无法调用工具搜索、计算、操作文件无法自主规划复杂任务每次需要用户完整描述需求Agent的价值自动调用工具获取信息记忆历史理解上下文主动推理和规划十四、如何解决上下文膨胀回答思路上下文膨胀指对话历史过长超过模型token限制。解决方案滑动窗口只保留最近N轮对话摘要压缩对历史对话生成摘要替代原始消息RAG检索不保留全量历史按需检索相关记忆分页/分段将长对话拆分成多个会话关键信息提取只保留关键事实和决策// 滑动窗口 摘要混合functionmanageContext(messages,maxTokens8000){lettokensestimateTokens(messages)if(tokensmaxTokens)returnmessagesconstsystemmessages[0]constrecentmessages.slice(-6)// 最近6条consttoCompressmessages.slice(1,-6)constsummarysummarize(toCompress)// 异步生成摘要return[system,{role:system,content:历史摘要${summary}},...recent]}十五、Agent要考虑哪些维度的问题回答思路设计Agent时的关键考量维度。核心维度推理能力如何让模型正确分解任务、选择工具记忆管理短期记忆对话上下文 长期记忆向量数据库工具调用工具定义、参数传递、结果解析、错误处理成本控制Token消耗、API调用次数安全性工具调用权限、敏感操作确认、防止滥用可观测性记录Agent的思考轨迹便于调试和优化效率并行执行、缓存优化、减少不必要的推理回答示例“设计Agent时我会考虑第一推理准确性——模型能否正确规划步骤第二记忆管理——如何处理长对话第三工具调用——如何安全地执行外部操作第四成本——控制Token和API调用第五可观测性——能追踪Agent的思考过程以便调试。”知识点速查表知识点核心要点BFC独立渲染区域清除浮动、防止margin重叠、自适应布局Flex布局左边flex:0 0 auto右边flex:1min-width:0数组遍历forEach/map/filter/reduce/some/every/find/for数组乱序Fisher-Yates洗牌避免sort随机重排重绘几何变化触发重排视觉变化触发重绘重排一定重绘优化重排transform、读写分离、批量样式、脱离文档流闭包函数外部作用域防抖/模块化/内存泄漏风险事件循环同步→微任务→宏任务多任务源有优先级React事件合成事件、事件委托root节点、事件池移除Agent工具调用、任务规划、记忆管理、错误恢复上下文膨胀滑动窗口、摘要压缩、RAG、关键信息提取Agent维度推理/记忆/工具/成本/安全/可观测性/效率 最后一句携程这场一面既考基础BFC、闭包、重排重绘、React事件又问前沿Agent、MCP、上下文膨胀。用户对左边flex布局的细节有些生疏但AI相关概念回答得不错。这提醒我们前端面试已不再局限于传统八股AI工程化能力正成为新的加分项。能紧跟技术潮流的人永远走在前面。

相关文章:

前端八股文面经大全:携程前端一面(2026-04-17)·面经深度解析

前言 大家好,我是木斯佳。 相信很多人都感受到了,在AI浪潮的席卷之下,前端领域的门槛在变高,纯粹的“增删改查”岗位正在肉眼可见地减少。曾经热闹非凡的面经分享,如今也沉寂了许多。但我们都知道,市场的…...

Edge Impulse实战:用Arduino Nano 33 BLE Sense的IMU数据,做个“手势识别”分类器

用Arduino Nano 33 BLE Sense实现手势识别的全流程实战 当Arduino Nano 33 BLE Sense开发板遇上Edge Impulse平台,内置的IMU传感器突然拥有了理解手势的能力。本文将带你完整实现从原始传感器数据采集到嵌入式AI模型部署的全过程,让一块普通开发板学会识…...

告别枯燥表单!我是如何用Lottie动画把React Native登录页的用户体验提升一个档次的(附LeanCloud后端代码)

用Lottie动画为React Native登录页注入情感化设计的实战指南 在移动应用的世界里,登录页面就像是一本书的封面——它决定了用户对产品的第一印象。然而,大多数应用的登录体验仍然停留在"用户名密码登录按钮"的三件套模式上,这种千篇…...

Vue + Electron 打包exe实战:从官网Demo到独立桌面应用的一站式配置

Vue Electron 桌面应用开发实战:从零构建到多平台打包 最近在技术社区看到不少关于Vue项目桌面化的讨论,很多团队都在探索如何将现有的Web应用快速转化为桌面端产品。恰好上个月我刚完成一个Vue项目的Electron封装,过程中踩了不少坑&#xf…...

Python Web应用负载均衡方案_结合Nginx权重设置实现高可用

Nginx upstream 权重未生效,主因是未启用加权轮询策略、存在 ip_hash 等冲突指令、weight 参数缺失或 Nginx 版本过低(需 ≥1.9.1);务必验证配置语法、检查健康检查设置及后端响应。nginx upstream 配置权重时,后端服务…...

5步搞定Gemma-3-12B-IT:无需代码基础,快速搭建AI对话平台

5步搞定Gemma-3-12B-IT:无需代码基础,快速搭建AI对话平台 1. 为什么选择Gemma-3-12B-IT? Gemma-3-12B-IT是Google最新推出的开源大语言模型,特别适合想要快速搭建AI对话平台的用户。相比前代版本,它在三个方面有明显…...

浅学线性回归与逻辑回归

1.什么是线性回归和逻辑回归 线性回归是一种用于建模连续目标变量与一个或多个自变量之间线性关系的统计方法,它的基本形式为y theta0 theta1*x theta2 * x*x .......。其中,我们会假设自变量与因变量存在线性关系,自变量之间相关性较低。 线性回归…...

ENVI实战:用ROI工具和外部矢量文件,5分钟搞定复杂区域的精准图像裁剪

ENVI高效裁剪实战:矢量边界与ROI工具在遥感影像处理中的精准应用 遥感影像处理中,图像裁剪是最基础却至关重要的环节。尤其当我们需要从覆盖数百平方公里的大范围影像中,精准提取出某个特定行政区划、生态保护区或流域边界时,传统…...

Canvas Quest在在线教育中的应用:个性化学习头像生成系统

Canvas Quest在在线教育中的应用:个性化学习头像生成系统 1. 教育场景中的个性化需求 在线教育平台面临一个共同挑战:如何让屏幕前的学习体验更具吸引力。传统头像系统往往提供有限的预设选择,难以反映学生的个性特点和学习历程。Canvas Qu…...

2026 复刻表口碑天花板:VS 厂断层领先成行业第一,C 厂 N 厂各有王牌

2026 复刻表口碑天花板:VS 厂断层领先成行业第一,C 厂 N 厂各有王牌2026 年,高端复刻表市场正迎来技术与需求的双重爆发。原装奢侈腕表价格持续高位,叠加消费者对机械性能和细节还原度的专业化要求,顶级复刻产品成为越…...

ODrive配置AS5047P磁编码器避坑指南:从SPI接线、参数设置到三种上电校准模式的深度解析

ODrive与AS5047P磁编码器实战:SPI配置优化与三种启动模式深度解析 在机器人关节、云台稳定系统等高精度运动控制场景中,无刷电机与绝对值磁编码器的组合已成为行业标配。AS5047P作为14位分辨率的SPI接口磁编码器,配合ODrive开源驱动器&#x…...

当Dijkstra遇上multiset:手把手教你用C++实现可动态更新的‘双货币’最短路径系统

当Dijkstra遇上multiset:手把手教你用C实现可动态更新的‘双货币’最短路径系统 在现实世界的路径规划问题中,我们常常需要处理多种成本因素的动态变化。想象你正在开发一个旅游路线规划系统,用户不仅需要考虑传统交通费用,还需要…...

YOLO12实战案例:YOLO12用于数字孪生工厂中设备状态视觉感知

YOLO12实战案例:YOLO12用于数字孪生工厂中设备状态视觉感知 1. 引言:当数字孪生遇到“火眼金睛” 想象一下,你是一家大型制造工厂的负责人。车间里,上百台设备日夜不停地运转,从冲压机到焊接机器人,从传送…...

Claude Code 有什么功能?能力全解析

在AI工具百花齐放的今天,像库拉KULAAI(t.kulaai.cn)这样的聚合平台为用户提供了便捷的一站式体验入口。而Claude Code作为Anthropic推出的AI编程助手,正在重新定义开发者的工作方式。本文将深入解析其核心功能与实战价值。一、核心功能:不只是…...

Hunyuan-MT-7B保姆级教学:非AI工程师也能部署的中文友好翻译系统

Hunyuan-MT-7B保姆级教学:非AI工程师也能部署的中文友好翻译系统 你是不是也遇到过这样的烦恼?想读一篇英文技术文档,但专业术语太多,翻译软件翻得词不达意;或者需要把一份中文报告翻译成日文,但找不到一个…...

忍者像素绘卷实战教程:为微信小程序定制1:1头像+2:1封面图双尺寸生成

忍者像素绘卷实战教程:为微信小程序定制1:1头像2:1封面图双尺寸生成 1. 工具介绍与环境准备 忍者像素绘卷是一款基于Z-Image-Turbo深度优化的图像生成工具,特别适合为微信小程序创建复古像素风格的视觉素材。它采用16-Bit游戏美学设计,能够…...

DAMO-YOLO手机检测结果结构化解析:JSON输出格式与数据库存储设计

DAMO-YOLO手机检测结果结构化解析:JSON输出格式与数据库存储设计 1. 引言:从检测框到结构化数据 当你运行一个手机检测模型,看到屏幕上出现一个个红色的方框时,你可能在想:这些检测结果怎么用起来?怎么保…...

PP-DocLayoutV3模型部署避坑指南:解决常见环境配置与依赖冲突

PP-DocLayoutV3模型部署避坑指南:解决常见环境配置与依赖冲突 部署一个AI模型,尤其是像PP-DocLayoutV3这样功能强大的文档版面分析模型,本该是件令人兴奋的事。但很多时候,这份兴奋感在第一步——环境配置上,就可能被…...

MiniCPM-o-4.5-nvidia-FlagOS应用场景:HR招聘中简历截图→关键信息提取→岗位匹配分析

MiniCPM-o-4.5-nvidia-FlagOS应用场景:HR招聘中简历截图→关键信息提取→岗位匹配分析 1. 引言:当HR遇上AI,招聘效率的质变 想象一下这个场景:你是一家公司的HR,邮箱里躺着上百份简历,每份简历都需要你手…...

从‘棋盘’到‘行军’:手把手解析SRAM测试中的March与Checkerboard算法,你的芯片选对了吗?

从‘棋盘’到‘行军’:SRAM测试算法实战选型指南 在芯片验证的战场上,SRAM测试算法的选择就像为不同地形配备最合适的战术方案。当存储单元数量突破百万级,一个低效的测试算法可能导致产线吞吐量下降30%以上,而错误的算法选择则可…...

别再死记硬背了!一张图帮你理清二叉树、AVL树、红黑树、B树、B+树的区别与选型

可视化决策指南:二叉树家族核心差异与工程选型实战 当你面对MySQL索引设计、语言标准库实现或系统架构优化时,是否曾被各种树结构的选型问题困扰?二叉查找树、AVL树、红黑树、B树与B树这五大经典结构,各自在时间复杂度、空间利用率…...

别再到处找了!这12个三维点云开源数据集,从自动驾驶到室内建模都能用

三维点云实战指南:12个开源数据集深度解析与应用场景匹配 在三维视觉和空间计算领域,点云数据正成为连接物理世界与数字世界的核心纽带。无论是自动驾驶车辆的环境感知、建筑BIM模型的逆向重构,还是工业质检中的三维测量,优质的点…...

Lychee-Rerank-MM一文详解:多模态重排序与传统文本重排序效果对比

Lychee-Rerank-MM一文详解:多模态重排序与传统文本重排序效果对比 1. 引言:当搜索遇到图片,传统方法还够用吗? 想象一下这个场景:你在网上搜索“适合周末野餐的便携椅子”,传统的搜索引擎会给你一堆文字链…...

GLM-4.7-Flash从部署到应用:完整实战案例,助你效率翻倍

GLM-4.7-Flash从部署到应用:完整实战案例,助你效率翻倍 1. 为什么选择GLM-4.7-Flash 在当今AI大模型百花齐放的时代,GLM-4.7-Flash凭借其独特的优势脱颖而出。作为智谱AI推出的最新一代大语言模型,它采用了创新的MoE&#xff08…...

SQL报表星型模型优化_事实表索引设计

...

快速上手VibeVoice:从环境检查到生成第一段AI配音

快速上手VibeVoice:从环境检查到生成第一段AI配音 1. 准备工作:了解VibeVoice VibeVoice是微软开源的一款轻量级实时语音合成系统,基于VibeVoice-Realtime-0.5B模型构建。它最大的特点是能够在输入文本后约300毫秒内开始播放语音&#xff0…...

LFM2.5-1.2B-Thinking-GGUF效果体验:自动化生成技术博客大纲与初稿

LFM2.5-1.2B-Thinking-GGUF效果体验:自动化生成技术博客大纲与初稿 1. 开篇:当AI遇见技术写作 技术写作从来不是件轻松的事。记得刚入行时,我常常对着空白文档发呆几小时,明明满脑子想法,却不知从何下笔。现在&#…...

DAMOYOLO-S模型效果对比展示:YOLOv8、YOLOv11性能横评

DAMOYOLO-S模型效果对比展示:YOLOv8、YOLOv11性能横评 最近在目标检测圈子里,DAMOYOLO-S这个名字被讨论得挺多的。它作为YOLO家族的一个新成员,主打的就是一个“又快又准”。但光听宣传没用,是骡子是马得拉出来遛遛。正好&#x…...

Qwen3-ASR-1.7B应用场景:会议录音转文字、方言识别、多语言翻译

Qwen3-ASR-1.7B应用场景:会议录音转文字、方言识别、多语言翻译 1. 模型概述 Qwen3-ASR-1.7B是阿里云通义千问团队开发的开源语音识别模型,作为ASR系列的高精度版本,它在多个实际应用场景中展现出卓越性能。这款1.7B参数的模型不仅支持普通…...

Qwen3.5-9B-AWQ-4bit C语言项目代码审查与注释生成工具开发

Qwen3.5-9B-AWQ-4bit C语言项目代码审查与注释生成工具开发 1. 嵌入式开发的代码质量痛点 在嵌入式开发领域,C语言依然是无可争议的王者。但每个经历过大型嵌入式项目的人都知道,维护那些充满指针操作和内存管理的代码有多痛苦。想象一下这样的场景&am…...