8.20 Minimax前端一面,被拷打

问的真的很难很深,面试官水平很高啊,被狠狠拷打,面试官人很好,给过了,同时也暴露了很多问题
全长一个小时左右,开始直接上难度
无八股,实习+项目+做题
1.微前端是什么概念,子应用之间如何实现环境隔离?
2.在eval里this指向哪里?如何改变eval的this?
eval函数只要是在全局直接运行或者是通过一个函数调用执行、作为对象属性被调用执行这种间接的执行方式,他的指向都是全局作用域。他不能直接被call/bind/apply改变this指向,改变的思路是在eval外面包一层函数,改变外面这个函数的this指向
3.上面说的那种方式没办法直接改变eval的this,因为eval的this永远指向外部函数的上下文,怎么直接改变?
使用with
4.new Function创建函数和普通创建函数的区别?
但是如果我们使用 new Function 创建一个函数,那么该函数的 [[Environment]] 并不指向当前的词法环境,而是指向全局环境。
因此,此类函数无法访问外部(outer)变量,只能访问全局变量。
5.eval执行的返回值是什么?如果传入一个字符串“undefined”,返回什么?
如果传的参数不是字符串,会被原封不动的返回,如果是字符串,字符串内是表达式,会执行表达式并返回结果,字符串内是语句,会被按顺序执行。如果是“undefined”,会返回undefined
6.项目中人员轨迹如何记录,怎么把轨迹点连成线?有看过底层实现吗?了解webGL吗
7.流程可视化编辑如何实现,有用过canvas吗
8.cookie多大?localstorage多大?
9.localstorage能跨域吗?和sessionstorage有什么区别
不能,只在同一个域名下生效
10.localstorage内存有限制,到限制了怎么办?
11.react用过哪些优化手段
手撕:动态规划找最短路径
问题不多,但是问的很细,太细就答不上来了,然后面了很久。
大家平时还是要多深挖一下
#minimax##前端##秋招#
全部评论
这考的都是啥,eval不用的东西还考这么多,为啥不在热门技术深挖,非要去挖冷门点。。
1 回复 分享
发布于 2024-08-26 16:08 天津
m
1 回复 分享
发布于 2024-08-23 23:32 黑龙江
咋跟我当时面的差很多 ,是那个男的面试官吗 说话带点风味的
1 回复 分享
发布于 2024-08-23 17:42 浙江
没事的,我简历直接挂了
点赞 回复 分享
发布于 2024-09-29 23:31 江苏
问这么偏,人为设置门槛吧
点赞 回复 分享
发布于 2024-08-26 17:18 北京
秋招吗
点赞 回复 分享
发布于 2024-08-23 17:03 浙江

相关推荐

飞书前端一面面经:从基础到实战的技术碰撞一、面试初印象这次飞书前端一面给我的整体感受是节奏紧凑且直击技术核心。面试官风格沉稳,问题由浅入深,既考察基础能力,又注重解决实际问题的思维,是一次很有价值的技术交流。二、面试问题复盘1. CSS 基础考察面试官开场便询问我 CSS 基础掌握程度,我坦诚表示“不是很好”,随后进入具体问题:如何实现三列布局,要求两边宽度固定,中间宽度自适应。我首先提到可以用 JavaScript 监听窗口变化动态调整宽度,但面试官希望用纯 CSS 方案。我迅速想到 Flex 布局,并详细解释了实现思路:.container {display: flex;}.left, .right {width: 200px; /* 固定宽度 */}.center {flex: 1; /* 自动分配剩余空间 */}接着,面试官追问 calc() 函数是否了解,由于平时使用较少,我仅简单说明了它能进行四则运算,用于动态计算 CSS 属性值,比如 width: calc(100% - 400px); 可以配合实现响应式布局。2. 项目与性能优化探讨当被问到 项目中的性能优化经验 时,我如实反馈:目前实习项目和个人项目经验较少,尚未深入接触性能优化模块。面试官没有追问,而是迅速切入算法题环节。3. 算法与代码实现题目1:封装 Promise 重试函数要求实现一个函数,传入请求的 Promise 和请求次数,请求失败时自动重试,达到次数上限后不再发起请求。我给出如下代码:function retryPromise(promise, times) {let count = 0;return new Promise((resolve, reject) => {const run = () => {promise.then(resolve).catch((error) => {if (count < times - 1) {count++;run();} else {reject(error);}});};run();});}题目2:实现对象深拷贝我先写出基础版本:function deepClone(obj) {if (typeof obj!== 'object' || obj === null) {return obj;}let result = Array.isArray(obj)? [] : {};for (let key in obj) {if (obj.hasOwnProperty(key)) {result[key] = deepClone(obj[key]);}}return result;}面试官进一步要求 考虑边界情况,我补充说明:若对象属性为数组,需递归处理数组元素;若属性为函数、正则等特殊类型,需特殊处理。例如,对于函数可直接返回原函数,对于正则可创建新的正则实例。三、反问环节我向面试官提出疑问:“为什么在前端面试中如此看重 CSS 基础?”面试官耐心解答:“CSS 是前端页面布局和视觉交互的基石,良好的 CSS 能力能确保页面高效渲染和兼容性,是支撑复杂业务开发的基础,所以我们会重点考察。”四、面试结果与总结幸运的是,面试结果显示 已通过一面。回顾过程,坦诚承认自身不足并积极思考问题,以及在算法题中清晰的逻辑表达是关键。后续准备二面时,我将重点补足 CSS 知识盲区,积累项目实战经验,尤其关注性能优化相关技术,同时加强对 JavaScript 细节和边界场景的理解。这次面试也让我深刻认识到,扎实的基础和灵活的思维永远是技术面试的核心竞争力。
查看5道真题和解析
点赞 评论 收藏
分享
评论
11
43
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务