字节前端实习一面(通过)

飞书前端一面面经:从基础到实战的技术碰撞

一、面试初印象

这次飞书前端一面给我的整体感受是节奏紧凑且直击技术核心。面试官风格沉稳,问题由浅入深,既考察基础能力,又注重解决实际问题的思维,是一次很有价值的技术交流。

二、面试问题复盘

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 细节和边界场景的理解。这次面试也让我深刻认识到,扎实的基础和灵活的思维永远是技术面试的核心竞争力。
全部评论
深拷贝还要考虑循环引用
点赞 回复 分享
发布于 06-09 20:27 黑龙江

相关推荐

07-11 22:24
已编辑
电子科技大学 Java
📍面试公司:猿辅导🕐面试时间:7.10💻面试岗位:后端太菜了,偶遇场景题,拼尽全力无法战胜,我只是一个想要实习的菜鸡,别拷打我了❓面试问题:1、介绍下黑马点评,是直接拿到run了下吗,自己有没有创新2、你用MQ做什么,为什么选择RabbitMQ,其他的了解过吗?秒杀的业务流程是什么3、Redis是用来做存储DB还是缓存DB,有什么区别4、秒杀场景里哪里存着真正的库存量?库存扣减都是在哪里做的,Redis和底层DB?5、Redis库存预减,那要是MySQL扣减失败怎么办,你怎么把库存还回去?6、你异步生成订单,用户这么得到订单的ID,ID这么生成的7、要是这个key过期了呢(不懂,就算是内存满了也不应该删除这种高频访问的key上吧)8、幂等性怎么保证的,重试的时间是怎么设计的,为什么这么设计9、数据一致性怎么保证,写频繁的情况下,MQ消息堆积这么办?10、你项目里的Redis是集群吗,集群有主节点吗,主节点之间有什么联系吗11、Redis的哨兵集群是怎么选择从节点的,哨兵是什么和一般的Redis实例有什么区别12、MySQL的三个日志,负责什么,redolog和binglog的写模式有什么不同,为什么这么设计13、Redis的线程模型,Redis的持久化操作,知道这么定位一个Key存在与否14、AQS的工作原理,等待队列的线程的状态是什么,会继续占用CPU吗15、join是在做什么,怎么知道结束了,future了解多吗16、大模型知道哪些,都拿来做什么,transform的内容可以聊聊吗17、视觉大模型呢,接触过哪些18、手撕:找峰值,二分法,先讲思路(力扣有原题:***********************************************************反问:1、业务:电商、个人体验、教研🙌面试感想:被拷打麻了,疯狂道歉,感觉烂了给我过了,我的猿神
查看17道真题和解析
点赞 评论 收藏
分享
评论
12
21
分享

创作者周榜

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