字节-国际化内容安全平台-前端一面

time:一个小时四十分钟

自我介绍

  1. pnpm 和 npm 有什么区别,和npm对比的话有什么优势?
  2. 硬链接和软链接的区别是什么?硬链接的优势是什么?
  3. 首屏优化思路
  4. 浏览器缓存静态资源的机制?
  5. 有哪些HTTP请求头在缓存中可能会用到?
  6. 场景题:如果有大量的图片应该如何设置相应的缓存策略?
  7. WebSocket深度拷打
    • WebSocket 和长轮询、gRPC Streaming、SSE 的区别是什么?
    • WebSocket 有什么好处?
    • (提到了资源占用)场景题:当客户端设备需要和多个服务器实例建立连接,
    • 场景题:如何完成事件广播?服务端一个emit如何让所有客户端都接受到?服务端如果连接了多个客户端实例,怎么能让消息进行可控的分发?
    • WebSocket 基于 HTTP 协议通过 101 进行升级,有些请求头是 hop-by-hop 而不是 end-to-end 的,能说一下对这个的了解吗?如果 WebSocket 需要配置请求头的话,需要配置什么请求头?
  8. 手撕
    1. 大数相加
    2. TS伪构造消息订阅
  9. 除了前端以外,有没有做过ETL(数据处理)的事情?有没有使用过ClickHouse?有没有了解过pivot?
    • 问这个应该是前面提到我有python爬虫的经验...
  10. 场景题:有很大很大的数据表,希望做一些数据的任务,希望放在sql中进行查询。如何把一个表中的部分数据通过中间表放入另外一个表中?有没有优化策略?思路是什么?
  11. 场景题:埋点上报,用户量非常大,观察用户行为是否有问题时,如何处理会比较好?思路是什么?
  12. 反问

面试官人非常好,后面反问聊了挺久的,在聊业务的时候介绍说主要是tiktok的相关内容,主要对接海外的部门,又说基本面的都是海外的同学,我是近期他面试第一个国内的应届生,给我搞傻了,估计是逗小孩子玩吧。。

不过收获还蛮多的,问题没有回答上来的时候,面试官总会耐心的讲解一波,总体感觉非常好,学到辣!

#牛客创作赏金赛##面试问题记录#
全部评论
我也面了这个岗,面试官人好好,蛮想去的,但是编程能力一般 没过
1 回复 分享
发布于 05-16 14:51 陕西
兄弟有后续了吗 ,我明天上午要面了
点赞 回复 分享
发布于 05-14 00:06 上海

相关推荐

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

创作者周榜

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