字节跳动-前端-暑期实习

3.14一面 85min

1.warmup

自我介绍

为什么选择前端

2.拷打项目

介绍一下是什么比赛,需求是什么?做了多久?

首页的放大镜效果:设计思路?用什么设计的(figma)具体如何实现的?(css蒙版+监听鼠标位置)【问的很细,他不清楚的地方会继续问】【上次字节日常实习一面的面试官让当场复现这段代码,今天没有】

适配移动端了吗?(做了横屏检测,但手机上样式会乱)面试官立刻点开手机上看【遗憾地发现没有适配】

说一个遇到的困难?(说了一个由 在组件挂载时依赖父组件传递的props导致数据延迟 引起的问题)【组件prop传值不是很明白原理,以为不会即刻更新,面试官进行了一个详细的教】【后来翻了当时记录说出来了】后来怎么解决的?(watch)

【因此展开问vue生命周期】

说一下vue生命周期?

如果组件依赖于要某个api获取的数据,应该在哪个生命周期获取数据?(我说我一般在setup里直接写)

created 和 mounted 的区别到底在哪?(好问题 不知道)

如果有一个异步函数需要很长的响应时间,组件在获取到数据之前是个什么状态?(我觉得是已挂载,但是无数据;数据获取到之后组件刷新)【这一块说的很乱,也不知道说的对不对,但面试官真的很好,在引导我说】

3.笔试

用ts/js写代码,20min 两道,第一道leetcode 257.二叉树的所有路径,第二道 53.最大子数组和

(第二题brute force了,问有没有优化方法,没想出来;第一题没写完,只写了递归函数,说了思路【面试官看起来听到DFS就ok了】)

4.基础知识提问

有了解Vue底层原理吗?说一下数据绑定是什么,什么原理?

css盒模型?

HTTPS和HTTP的区别?

5.反问

前端工程师最重要的能力是什么?(答:技术能力,业务能力-对业务的理解、反哺产品(所以会问怎么设计的))

技术能力的要求?(答:实习生能做事就可以,工作三年要求能解决绝大部分的问题)

对暑期实习生和秋招生的技术能力要求的不同?

技术栈?需要会React吗?(答:都是React。不用,这是短时可以获取的能力)

建议?(答:做过的学过的深度了解,先有深度再有广度)

全部评论
QL2QR92 来考虑下团子吧,可以帮看简历,关注流程!
点赞 回复 分享
发布于 03-16 08:56 河北
结果怎么样,我也是昨天面的
点赞 回复 分享
发布于 03-15 20:52 重庆

相关推荐

飞书前端一面面经:从基础到实战的技术碰撞一、面试初印象这次飞书前端一面给我的整体感受是节奏紧凑且直击技术核心。面试官风格沉稳,问题由浅入深,既考察基础能力,又注重解决实际问题的思维,是一次很有价值的技术交流。二、面试问题复盘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道真题和解析
点赞 评论 收藏
分享
评论
9
42
分享

创作者周榜

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