小米前端面经(社招)

news/2025/2/12 19:03:38/

前言

近一段时间我投了不少大厂的前端岗位,但是由于刚刚参加工作一年多点,所以要么简历没过筛选,要么面试一两轮就挂了,之前面试过阿里的,两轮挂了,头条一面没过,于是这段时间来自己又总结之前的面试经验,为自己充电。
事情发生在一个月黑风高的夜晚,不对,说顺嘴了,抱歉!!事情发生在周五的一个傍晚,我正在参加公司的团建活动,大家聚餐比较热闹,吃完饭才发现有一个陌生号码。但是我拨回去却打不通了,当时我就觉得是某家公司的面试通知,想了想最近投过的公司,想到了小米,然后度娘了一下那个电话,虽然没搜到具体信息,但是百度的相关消息里有一条是号码******是小米的招聘电话吗,我一看,好吗前几位和我这个一模一样,然后心里就觉得是小米的概率会比较大。
无奈赶上了周天,我打了这个电话一直没人接,直到周一晚上才打通,一问果然是小米的面试邀请!(要是没打回去的话估计连面试的机会都没了。。。),对,提前说一下,小米的社招一共是四轮面试,三轮技术面急+一轮hr面。

面试经过

按照和hr小姐姐约好的时间,我提前半小时到达目的地,本以为会是清河的小米大厦,不过邮件上给的地址是在西二旗的小米四期。由于他们下午两点半上班,所以我在外面等一一会儿,然后一个挺帅气的小哥哥出来了,也就是一面的面试官。面试官找了一个比较清静的地方开始了第一轮技术面,话不多说,直接上干货。

一面

  1. 你对vue掌握多少?
  2. vue双向绑定的实现原理说一下?数据劫持+订阅发布模式,订阅发布模式如何实现?
  3. vue中key的作用?vue有原地服用的原则,通过key决定是否对元素复用,如果不绑定key会引起什么问题?
  4. vue父子组件间怎么进行通信?
  5. 平时怎么处理多个同级组件间的通信的?vuex用的比较多,event bus有了解,但是没用过。。。
  6. vuex的组成?store,action,mutation,modules,分别讲一下各自的作用?
  7. 有写过vue异步组件吗?
  8. 有自己在npm上发布过依赖包吗?没有。。。。
  9. webpack的作用是什么?开发环境和测试环境之间的配置文件有什么区别?
  10. devtool有那些选项,分别有什么作用?我只说了sourse-map和eval-source-map
  11. devServer的实现原理了解过吗?没有。。。
  12. 说一下event loop的过程?宏任务和微任务巴拉巴拉。。。
  13. reqeustAnimationFrame有用过没,是如何使用的?就是递归调用呗。她是属于微任务还是宏任务?我说的微任务,下来度娘才知道是宏任务。
  14. promise定义时传入的函数什么时候执行的?立即执行。
  15. promise.all用过吗?如何实现当其中一个promise抛出错误的时候也能顺利执行promise.all的回调?我当时想的是不让错误进入到catch阶段,而是强行resolve一个提示错误的信号,但是具体怎么实现没太想好,后来查资料知道是通过在promise里设置try catch语句当异步操作出错时强行resolve一个信号,这样就不会跑到promise.catch里了。
  16. css里的flex布局用过吗?用过,垂直居中,自适应。原理了解过吗?没有。。。
  17. 时间模型的三个阶段说一下?三个嵌套的div,每个div都同时绑定一个捕获事件和一个冒泡时间,写出事件执行顺序?
  18. 事件代理?父节点定义了多个点击事件,点击子节点,如何实现一个事件不执行,其他所有的事件都执行?用stopDefault()组织该事件默认行为。
  19. 如何阻止冒泡?在时间中调用stopPropagation()。
  20. 浏览器的缓存机制?
  21. 前端工程化的理解?前后端分离巴拉巴拉。。。部署方面呢?没太答上来。
    一面就这么结束了,大概一个小时吧,然后小哥哥让我等一会儿。

二面

过了十分钟左右吧,另外一个小哥哥来了,这一面是其他部门的面试官,也就是交叉面。

  1. 平时pc端做的多还是移动端做的多?pc,移动端主要做一些自适应和响应式布局。
  2. 主要是通过什么手段实现响应式布局的?媒体查询配合弹性布局,rem之类的。
  3. 做移动端适配的时候需要设置什么?<meta name=“viewport” content=“width=device-width;initial-scale=1;”>
  4. 详细说一下viewport?visual port、layout port、ideal port巴拉巴拉。。。。
  5. 做过动画吗?css动画和reqeustAnimationFrame比较?
  6. css动画实现一个div平移动画,用translate和left有什么区别?
  7. flex布局了解吗?平时主要是做自适应和水平居中,用flex写一个水平垂直居中?
  8. 手写了一个react组件,组件里有A和B两个子组件,A组件属性接受了父组件的state属性,B组件没有接受state属性,当父组件setState之后,如何变化?我回答的是A更新B不更新,面试官给我纠正了一下,A、B的render都会执行,在react中,父组件更新,默认是会更新所有子组件、孙组件的。这种情况下,你必须重写shouldComponentUpdate方法,自行判断这个组件是否需要更新,return false就会阻止更新。
  9. 还是刚刚的组件,实现一个异步获取数据列表[‘a’, ‘b’, ‘c’…],然后将这个数组中的数据渲染到dom中去的功能,最终是一个dom列表(<li>)。在componentMounted钩子里异步操作然后setState就ok了。为什么用componentMounted?因为此时dom节点已经挂载完毕,可以安全的对dom进行访问。
  10. react展示组建和功能组件的区别?
  11. react定义事件?使用前需要bind。
  12. es6新特性说一下?let、var、const区别?es6如何实现块级作用域的?
  13. WeakMap用过吗?没。。。
  14. promise.all?如何实现一个链式异步请求,一个请求完成继续下一个请求?then链式执行呗。中间如果有一个promise出错怎么办?如何确保执行到最后?我答的还是try catch前行resolve,不过好像不太对,有知道的大神求指导。
  15. promise、async/await、generator区别?
  16. 手撕代码:找出一个字符串中重复次数最多的字母?
  17. 手撕代码:实现对象的深克隆?
    二面结束,我跟小哥哥说明了下我的情况,请假出来面试不太方便,尽量一次性面完,小哥哥让我等一会儿,然后是等待时间。。。

三面

三面的时候脑子已经有点儿晕了稍微,尽量保持清醒。三面是最后一轮技术面,果不其然,是一个比较有气场的小哥哥,比较帅气,不出意外的话应该是部门的技术leader。三面的气氛感觉和前面明显不一样,问的问题也不再局限于前端,有简历上的经历,也有计算机相关的其他领域的知识,综合性很强,其实这是最头疼的,有些问题没涉足过,真的不太了解。。。
首先上来是一道经典的两侧定宽,中间自适应的题目,但是加了点东西,就是头部一个header,header下面是经典案例,但是要求各个元素有显示顺序,header->center->left->right,我当时直接用了浮动:

<!DOCTYPE HTML>
<html>
<style>.parent {text-align: center;width: 500px;height: 400px;}.up-wrap {background-color: #ccc;height: 30%;}.down-wrap {overflow: hidden;height: 70%;}.left {background-color: #f00;width: 100px;height: 100%;float: left;}.right {background-color: #f00;width: 100px;height: 100%;float: right;}.center {background-color: #cc2;margin-left: 100px;margin-right: 100px;height: 100%;} 
</style>
<body><div class="parent"><div class="up-wrap">1</div><div class="down-wrap"><div class="center">2</div><div class="left">3</div><div class="right">4</div></div>
</div></body>
</html>

当时以为清除浮动就万事大吉,但是忘了left、right需要定义在center前面才会不换行,但是题目要求的是center首先显示,因为必须是center在left、right前面,这样会导致一个问题,center是块状元素,left、right会被挤到下一行,导致left、right不可见。
面试回来后由写了一下,改用绝对定位就好了,直接彻底脱离文档流:

<!DOCTYPE HTML>
<html>
<style>.parent {text-align: center;width: 500px;height: 400px;}.up-wrap {background-color: #ccc;height: 30%;}.down-wrap {overflow: hidden;height: 70%;position: relative;}.left {background-color: #f00;width: 100px;height: 100%;position: absolute;left: 0;top: 0;}.right {background-color: #f00;width: 100px;height: 100%;position: absolute;right: 0;top: 0;}.center {background-color: #cc2;margin-left: 100px;margin-right: 100px;height: 100%;} 
</style>
<body><div class="parent"><div class="up-wrap">1</div><div class="down-wrap"><div class="center">2</div><div class="left">3</div><div class="right">4</div></div>
</div></body>
</html>

面试官看我研究生期间做过图像处理,问我为什么没从事这个,我说研究生两年时间只够入个门,然后实习做的也是前端,渐渐的就喜欢上了前端,说了一下我的毕业设计内容,然后给我出了一道算法题,给了我一组坐标点list,让我求经过所有点的最短路径组合,我想了半天,只能想到最简单粗暴的方法,排列组合求出所有路径的长度,取最大值,但是这显然是复杂度很高的做法,然后面试官提示我用分治思想,我最终还是没写出来。然后让我写了个“双飞燕”布局,按照顺序加载dom节点,并且能撑满高度,中间我写的一些地方面试官认为有点儿问题,然我回去试一下。再然后面试官问我想离职的原因,我说希望能进入更大的平台提升自身技术能力,然后聊了半天,面试官也给我提了一些学习成长的建议,挺受启发的。然后聊到关注react17和vue3的时候,面试官突然想到了diff算法,让我手写一个深度判断两个对象是否一致的函数,我写了一下,用的递归,但是中间分情况讨论的地方可能有的情况没写出来,就写了个大概实现。
然后问了webpack打包会生成hash名称,怎么判断这个资源是否变了,我说etag,面试官又问我etag怎么生成的,我一知半解的说了一些,后台的了解的不多。
最后就是熟悉的问问题环节,我问了下他们现在主要做什么内容,用的技术栈,还有面试结果多就能知道,面试官说他知道的都在一到两周内有恢复,如果技术面通过会有hr联系。为时四个小时的小米面试之旅就这样画下了句号。

结语

这应该算是我毕业一年来去大厂面试第一次面完三轮技术面,因为我本科并不是计算机系的,研究生才开始接触的代码,所以基础相对差一些,这次面试我也不太抱希望,就当是一个对自己知识技能的检验了,即使没通过,一年以来的学习也有进步了,一直保持学习的步伐,我相信迟早会实现进入互联网大厂的梦想~加油了!


http://www.ppmy.cn/news/502302.html

相关文章

小米从北京迁往武汉南京,一线大厂逃离或为新常态?

近日有网友爆料小米将从北京迁往武汉南京的政策&#xff0c;在2019年年底3月前完成搬迁的员工可享受3万元补贴&#xff0c;可申请当地人才公寓。 按照这份公告的爆料&#xff0c;小米员工从北京“搬迁”到武汉南京后&#xff0c;工资待遇基本不变&#xff0c;公司会为员工提供1…

北京市大兴区卫星地图下载

一、概述 大兴区位于北京市南部&#xff0c;东临通州区&#xff0c;南临河北省固安县、霸州市等&#xff0c;西与房山区隔永定河为邻&#xff0c;北接丰台、朝阳区。东经11613′-11643′&#xff0c;北纬3926′-3951′。全境属永定河冲积平原&#xff0c;地势自西向东南缓…

直播预告 | 北京大学、北京航空航天大学、阿里巴巴、小米的四位讲者来啦!...

点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入&#xff01; 4月27日、28日晚19:30&#xff0c;ACL预讲&#xff0c;我们邀请北京大学计算语言所实习生陈亮、北京航空航天大学博士生牛广林、阿里巴巴达摩院算法工程师惠彬原和小米人工智能实验室高级算法工程师李嫣然给大家…

小米 2015 北京 研发面试

本系列文章是根据女朋友今年找工作的经历整理而成&#xff0c;虽然过程比较艰辛&#xff0c;但是女朋友也算很早就拿到offer的一批人&#xff0c;在这过程中在&#xff23;&#xff33;&#xff24;&#xff2e;中受益匪浅&#xff0c;同样&#xff0c;也希望我们的经验和教训也…

北京大兴计算机学校排名2015,北京大兴区小学排名

小学教育是学习受教的基础&#xff0c;所以选择一个好的小学是十分重要的。许多家长为了选择小学操碎了心。北京大兴区小学很多&#xff0c;下面小学排行榜为大家介绍北京大兴区小学排名的最新榜单! 北京大兴区小学排名--含重点 1、团河小学 2、大兴九小 3、北师大大兴附小 4、…

小米售后北京凌安信通讯技术服务有限公司西红门分公司经历

小米笔记本维修经历 笔记本型号问题描述预约维修到店维修感受 笔记本型号 小米笔记本电脑Pro 15.6’ A58721DD/CN&#xff1b; 原装固态硬盘&#xff0c;无维修记录&#xff0c;无改装和加装。 问题描述 8月23日上班后开机出现“No Bootable Devices”&#xff0c;无法进入系…

Sui Move HackerHouse预热开启,9月大理见

9月3日&#xff0c;Sui Move 主题的 Antalpha HackerHouse 将在大理举办&#xff0c;为期 21 天&#xff0c;向所有 Web3 开发者发出 co-buidling & co-living 邀请。 本期 HackerHouse 由 Antalpha Labs 发起&#xff0c;Sui Foundation赞助&#xff0c;MoveFuns DAO、No…

AI建模可以智能到什么程度?

2023年年初&#xff0c;我们被AIGC&#xff08;人工智能生产内容&#xff09;撞了个满怀&#xff0c;从AI绘画、AI写作、AI配音&#xff0c;到AI建模&#xff0c;似乎每个行业的内容创作者都被AI“击中了膝盖”。AI技术发展迅速&#xff0c;前段时间&#xff0c;国内外各大公司…