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

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 重庆

相关推荐

字节跳动Data AML部门前端实习一面面经本次面试时长1小时,主要涵盖项目经历、技术原理、基础知识和算法编程等方面,具体内容如下:一、项目经历面试官首先询问了实习项目相关内容,围绕项目背景、技术实现、遇到的问题及解决方案展开交流,考察对实际项目的参与度与理解深度。二、Suspense原理及实现1. 原理:Suspense 是 React 用于处理异步渲染的组件,可在数据加载或组件渲染完成前展示加载指示器,提升用户体验。2. 实现方式:被问到在 useEffect 中存在 fetch 请求时,如何让顶层组件感知组件存在异步请求。回答可通过 React Context 实现信息透传,但存在更优方案,可从 React 的新特性或状态管理库角度进一步优化 。三、JS基础1. var、let和const的区别:var 存在变量提升,会导致变量在声明前可被访问;let 和 const 具有块级作用域,更加安全。2. var逐渐被弃用原因:var 没有块级作用域,在复杂代码中容易引发变量覆盖等意外问题,使用 let 和 const 可避免此类风险,提高代码的可读性和稳定性。四、CSS基础1. 三列瀑布布局(两边固定,中间自适应):纯CSS可通过浮动或绝对定位实现;使用flex布局更优雅,flex: 1 表示该元素会自动分配剩余空间。2. flex常用属性:主要涉及主轴和横轴方向设置,如 flex-direction 定义主轴方向;常用的居中属性包括 justify-content: center(主轴居中)和 align-items: center(交叉轴居中) 。3. CSS动画:通过 animation 属性实现,配合关键帧 @keyframes 定义动画的起始和结束状态、变化函数(如线性变化)以及时间等参数。animation 在渲染进程的合成线程执行,不会阻塞JS执行,效率较高。五、算法编程题1. 合并有序链表// 定义链表节点结构function ListNode(val, next) {    this.val = (val === undefined? 0 : val);    this.next = (next === undefined? null : next);}var mergeTwoLists = function(l1, l2) {    const dummy = new ListNode(0);    let current = dummy;    while (l1 && l2) {        if (l1.val < l2.val) {            current.next = l1;            l1 = l1.next;        } else {            current.next = l2;            l2 = l2.next;        }        current = current.next;    }    current.next = l1 || l2;    return dummy.next;};2. 二叉树寻找公共父节点(节点有parent指针)function lowestCommonAncestor(p, q) {    const set = new Set();    while (p) {        set.add(p);        p = p.parent;    }    while (q) {        if (set.has(q)) {            return q;        }        q = q.parent;    }}3. 实现sum函数curry化   
查看11道真题和解析
点赞 评论 收藏
分享
评论
9
42
分享

创作者周榜

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