jawil / blog

Too young, too simple. Sometimes, naive & stupid 🐌
7.89k stars 840 forks source link

面试分享:一年经验初探阿里巴巴前端社招 #22

Open jawil opened 7 years ago

jawil commented 7 years ago

一般阿里社招都是招3-5年的P6+高级工程师,当初自己一年经验也没有想过有这个面试机会。

虽然没想着换工作,但是经常关注一些招聘网站的信息,某一天,在某boss上有个人找我,叫我发一下简历,我一看是阿里的某技术专家,虽然之前也有阿里的在某boss上给我要简历,但是我深知自己经验不足,然后给boss说我是16届的,只有一年经验,然后就没有然后了。这次我依然这么回复,但是这boss说,没关系,他喜欢基础好的,让我可以试一试,于是我也抱着试一试的心态发了简历。

简历发过去之后,boss就给我打了电话,让我简单的介绍一下自己,我就噼里啪啦说了一些,还说了一些题外话。然后boss就开始问我问题。

由于面了四轮,所以最开始的面试记忆有点模糊了,细细回想,又感觉记忆犹新。

1.电话初探

1.说一下你了解CSS盒模型。

我就说了一下IE的怪异盒模型和标注浏览器的盒模型,然后可以通过box-sizing属性控制两种盒模型的变换。

2.说一下box-sizing的应用场景。

这个也不难,简单说了一两个应用场景,具体就不一一细说了。

3.说一下你了解的弹性FLEX布局.

这个我也比较了解,各种概念和属性能想到的说了一大堆,也扯到了Grid布局,基本这个也没啥问题。

4.说一下一个未知宽高元素怎么上下左右垂直居中。

说了一下flex弹性布局的实现,说了一下兼容性,扯到了postcss的一些东西,然后说了一下常规的兼容性比较好的实现。

5.说一下原型链,对象,构造函数之间的一些联系。

这个我之前写过相关的文章,自己也有比较深入的理解,所以这个也不在话下,噼里啪啦说了一大堆,也不知道面试官听得咋样。

6.DOM事件的绑定的几种方式

说了三种,然后说了一些冒泡,默认事件,以及DOM2,DOM3级的一些标准。

7.说一下你项目中用到的技术栈,以及觉得得意和出色的点,以及让你头疼的点,怎么解决的。

这个因人而异,开放性问题,主要考察平时项目的一些积累吧,这个我回答感觉也比较ok。

8.有没有了解http2.0,websocket,https,说一下你的理解以及你所了解的特性。

这个我看过一些文章,但是没有什么印象,扯了一些概念,但是回答的不是很深。

第一轮电话初探,大约面了50分钟,就记起来这么多,还有一些细节问题可能淡忘了,总体来说,面的都是以基础为主,然后boss说把我简历推荐给内部,进行正式的社招流程。

一轮技术面

然后当天晚上一个女的面试官就给我打电话了,说八点半进行下一轮技术面试,没想到效率这么快,我都没怎么准备。 这次就直接省略自我介绍了。

1.webpack的入口文件怎么配置,多个入口怎么分割啥的,我也没太听清楚。

这个自己就说了一下自己的理解,以及自己用node写的多入口怎么配置,然后面试官说不是多入口配置,然后我又说了一下自己的理解,然后这题就过了。

2.我看到你的项目用到了Babel的一个插件:transform-runtime以及stage-2,你说一下他们的作用。

这个我也还算比较了解,就说了一下ES的一些API,比如generator啥的默认不转换,只转换语法,需要这个来转换,然后说profill啥的,扯了一下stage-1,stage-2,stage-3,这个问题回答还算清楚。

3.我看到你的webpack配置用到webpack.optimize.UglifyJsPlugin这个插件,有没有觉得压缩速度很慢,有什么办法提升速度。

这个我主要回答了一下,我之前也没怎么了解,一个想到是缓存原理,压缩只重新压缩改变的,还有就是减少冗余的代码,压缩只用于生产阶段,然后面试官问还有呢?我就说,还可以从硬件上提升,可以得到质的飞跃,比如换台I9处理器的电脑。。。。

4.简历上看见你了解http协议。说一下200和304的理解和区别

这个噼里啪啦说了一堆,协商缓存和强制缓存的区别,流程,还有一些细节,提到了expires,Cache-Control,If-none-match,Etag,last-Modified的匹配和特征,这一块之前有过比较详细的了解,所以还是应答如流。

5.DOM事件中target和currentTarget的区别

这个没答上来。。。

6.说一下你平时怎么解决跨域的。以及后续JSONP的原理和实现以及cors怎么设置。

我就说了一下Jason和cors,然后问我JSONP的原理以及cors怎么设置,这一块自己也实践过,所以还是对答如流的。

7.说一下深拷贝的实现原理。

这个也还好,就是考虑的细节不是很周全,先是说了一种JSON.stringify和JSON.parse的实现,以及这种实现的缺点,主要就是非标准JSOn格式无法拷贝以及兼容性问题,然后问了我有么有用过IE8的一个什么JSON框架,我也不记得是什么了,因为我压根没听过,然后说了一下尾递归实现深拷贝的原理,还问了我typeof null是啥,这个当然是Object。。。

8.说一下项目中觉得可以改进的地方以及做的很优秀的地方?

这个也是因人而异,开放性问题,大致扯了一下自己的经历,也还OK。

最后问了有什么需要问的地方,面试到这里基本就结束了,大约面了一个多钟头,还是蛮累的。总体来说,回答的广度和深度以及细节都还算OK,觉得这轮面试基本没什么悬念。

二轮技术面

过了几天,接到阿里另一个面试官的电话,上一轮面试通过了,这次是二轮技术面,说估计一个钟头。这次依然跳过自我介绍之类的,直奔主题。

1.有没有自己写过webpack的loader,他的原理以及啥的,记得也不太清楚。

这个我就说了一下,然后loader配置啥的,也还ok。

2.有没有去研究webpack的一些原理和机制,怎么实现的。

这个我简单说了一下我自己了解的,因为这一块我也没深入去研究,所以说的应该比较浅。

3.babel把ES6转成ES5或者ES3之类的原理是什么,有没有去研究。

这一块我说了一下自己的思路,大致也还OK,我也没去深入研究怎么转换的,之前好像看过类似的文章,自己也只观察过转换之后的代码是啥样的,至于怎么转换的规则,真的没去深入观察。

4.git大型项目的团队合作,以及持续集成啥的。

这里我就说了一下自己了解的git flow方面的东西,因为没有实战经验,所以我就选择性说明了这一块的不熟练,然后面试官也没细问。

5.什么是函数柯里化?以及说一下JS的API有哪些应用到了函数柯里化的实现?

这个我就说了一下函数柯里化一些了解,以及在函数式编程的应用,最后说了一下JS中bind函数和数组的reduce方法用到了函数柯里化。

6.ES6的箭头函数this问题,以及拓展运算符。

这一块主要是API和概念的问题,扯了一些规范以及严格模式下其他情况this只想问题。

7.JS模块化Commonjs,UMD,CMD规范的了解,以及ES6的模块化跟其他几种的区别,以及出现的意义。

这个也是说了一下自己的理解和认知,自己对模块化历史以及一些规范都有所涉猎,这一块也还凑合。

8.说一下Vue实现双向数据绑定的原理,以及vue.js和react.js异同点,如果让你选框架,你怎么怎么权衡这两个框架,分析一下。

主要是发布订阅的设计模式,还有就是ES5的Object.defineProperty的getter和setter机制,然后顺便扯了一下Angular的脏检测,以及alvon.js最先用到这种方式。然后扯了一下vue.js和react.js异同点,权衡框架选择,调研分析之类,噼里啪啦说了一大堆。

9.我看你也写博客,说一下草稿的交互细节以及实现原理。

这一款就按照自己用过简书或者掘金,SG这类草稿的体验,详细说了一下,这个开放性问题,说到点基本就OK。

最后面试官问我有什么想问的吗,面试到这里基本就结束了,差不多面了一个小时,说过几天就会给答复,如果过了就会去阿里园区进行下一轮的技术面。

三轮技术面

上一轮发挥感觉没前两轮发挥好,所以还是有点不自信的,没想到第三天后,就来电话了,通知我去阿里园区面试。

因为阿里西溪园区距离我不到十公里,我就踩着共享单车一点钟就出发了,天气比较热,飘在路上,百感交集,身边一辆法拉利轰鸣而过,又一辆兰博基尼呼啸而过,我心里一万头草泥马奔腾,MLGB,心里暗想,为神马开这车的人不是此刻看文章的你?

走到半路了,面试官给我打电话了,说我怎么还没到,说约定的是两点钟,我一下子就懵逼了,短信只有一个游客访问ID,并没有通知我具体时间,反正不管谁的疏忽,我肯定是要迟到了,于是我快马加鞭,踩着贼难骑的共享单车,背着微风,一路狂奔,到阿里园区已是汗流浃背,油光满面,气喘乎乎。。。

面试迟到了,印象肯定不好,加上满头大汗的形象也不太好,加上自己饥渴难耐,这面是估计要GG了,一进来就直奔主题,这次是两个大Boss面试我。

第一个面试官

1.先自我介绍一下,说一下项目的技术栈,以及项目中遇到的一些问题啥的。

这个问题就是个开场白,简要说明一下,问题都不大,这个面试官就是第一次打电话给我面试的那个boss,所以技术那块boss心里也有个底细,所以没再问技术问题。

2.一个业务场景,面对产品不断迭代,以及需求的变动该怎么应对,具体技术方案实现。

具体业务场景,我就不一一描述,Boss在白板上画了一个大致的模块图,然后做了一些需求描述。 然后需求一层一层的改变,然后往下挖,主要是考察应对产品能力,以及对代码的可维护性和可拓展性这些考察,开放性问题,我觉得还考察一些沟通交流方面的能力,因为有些地方面试官故意说得很含糊,反正就是一个综合能力,以及对产品的理解,中间谈到怎么实现,也问到了一些具体的点,记得问到的有一下几个。

① 怎么获取一个元素到视图顶部的距离。 ② getBoundingClientRect获取的top和offsetTop获取的top区别 ③事件委托

第二个面试官

1.业务场景:比如说百度的一个服务不想让阿里使用,如果识别到是阿里的请求,然后跳转到404或者拒绝服务之类的?

主要是考察http协议头Referer,然后怎么判断是阿里的ip或者啥的,我也不太清楚。

2.二分查找的时间复杂度怎么求,是多少

。。。排序的还算清楚一点,查找真的不知所措,没回答上来,也没猜,意义不大,不会就是不会。

3.XSS是什么,攻击原理,怎么预防。

这个很简单,跨站脚本攻击XSS(cross site scripting),攻击类型主要有两种:反射型和存储型,简单说了一下如何防御:

①转义 ②DOM解析白名单 ③第三方库 ④CSP

自己对web安全这块系统学习过,前前后后大约了解了很多,对于XSS,CSRF,点击劫持Cookie安全HTTP窃听篡改密码安全SQL注入社会工程学都有一定了解,所以这个自然也不在话下。

4.线性顺序存储结构和链式存储结构有什么区别?以及优缺点。

我是类比JS数组和对象来回答的,反正还算凑合吧,自己都数据结构这块多少还是有些印象,所以入了前端,对数据结构和算法确实一直淡忘了。

5.分析一下移动端日历,PC端日历以及桌面日历的一些不同和需要注意的地方。

这个我能想到的大致都说了一遍,不同的场景交互和细节以及功能都有所偏差,以及功能的侧重都可能不同。

6.白板写代码,用最简洁的代码实现数组去重。

我写了两种实现方式: ES6实现:

[...new Set([1,2,3,1,'a',1,'a'])]

ES5实现:

[1,2,3,1,'a',1,'a'].filter(function(ele,index,array){
    return index===array.indexOf(ele)
})

7.怎么实现草稿,多终端同步,以及冲突问题?

这个回答的不算好,本来也想到类比git的处理方式,但是说的时候往另外一个方面说了,导致与面试官想要的结果不一样。

最后说目前的工作经验达不到P6水平,业务类稍弱,阿里现在社招只要P6的高级工程师,但是可以以第二梯队进去,就是以第三方签署就业协议,一年后可以转正,就是俗称的外包。多少还是有点遗憾,面了四轮面了个外包,最后放弃这份工作了。

最后,感谢boss一直以来的关照和器重。

bhaltair commented 7 years ago

没想到竟然是一个福利贴

gy134340 commented 7 years ago

大佬,草榴还要人吗

jawalkwan commented 7 years ago

@jawil 我是来瞻仰大佬并且求码的,好人一生平安fuck@fackyou.org

joe223 commented 7 years ago

比心摸摸哒

jkchao commented 7 years ago

大兄弟,加油!

gladysyang commented 7 years ago

厉害了我的哥

FrontToEnd commented 7 years ago

看完后默默地学习吧。。。

Recklesslmz commented 7 years ago

好吧,我根本不是前端,我只是个会写代码的混子,扎心啊

Richard-Choooou commented 7 years ago

在草榴工作是怎样的体验?会肾虚吗?233

junhey commented 7 years ago

看完还是好好敲代码了😀

taizhengfs commented 7 years ago

阿里招司机,面试官问: 你知道发动机的原理吗?你知道离合器是如何实现的?发动机的曲柄连杆机构是做了什么事情?电控燃油喷射系统工作的原理?简单说说辛普森式行星齿轮变速器的结构和工作原理吧。汽车上有哪些常用的螺丝?有手写过螺丝吗?有自己合成过轮胎上橡胶吗?什么?这些你都不清楚那你还开什么车?。。是是是,面试官说的对,我回去再看看,经验不足经验还差了点

ghost commented 7 years ago

昨天才被内推阿里,按这样的话,我是不是连一面都过不了了。😂 😂

jawil commented 7 years ago

很不幸,你可能连简历都过不鸟,人艰不拆。😂😂😂 @yanshaojing

monw3c commented 7 years ago

求带求带😂

CoderLeftEar commented 7 years ago

卧槽,居然没发现是车队,一直以为草榴是Lz的笔名之类的,23333

ghost commented 7 years ago

@jawil 再见

hstarorg commented 7 years ago

我这6年开发,3年偏前端方向的,基础上自愧不如啊。

boboyangmoumou commented 7 years ago

我也是前端来看的,顺便上车队

jayce712 commented 7 years ago

同楼主同一年毕业,一直感觉在同等工作经验中水平偏中上,和楼主比被虐到不行

FoxDaxian commented 7 years ago

老哥 能不能看看你的简历呢?如果可以的话,发我邮箱,谢谢! 945039036@qq.com

RoseWebOnly commented 7 years ago

求邀请码

jawil commented 7 years ago

看简历有何居心,给我一个理由😂😂 @a13821190779

RoseWebOnly commented 7 years ago

@jawil

RoseWebOnly commented 7 years ago

感觉你很厉害自愧不如

FoxDaxian commented 7 years ago

没啥居心啊...就是想学习一下,参考一下大佬的技术栈,向大佬靠齐啊 @jawil

kevinaskin commented 7 years ago

在草榴工作是一种怎样的体验?

jawil commented 7 years ago

😂,基本上就是简历上问的,还有一些node.js和Linux,Nginx这些知识,估计是面试前端,所以面试没问@a13821190779

useryangtao commented 7 years ago

http://www.cnblogs.com/aishangJava/p/7337718.html

FoxDaxian commented 7 years ago

@jawil 好吧,我之前被朋友内推美团,简历都没过,好尴尬..

jawil commented 7 years ago

毫无人道啊,我只分享到了掘金和SG了,这个网站我没玩过,太杂了。。。 @useryangtao

jawil commented 7 years ago

美团简历评判标准,看看你挂在哪里?

https://juejin.im/post/58b6679461ff4b006ccd825e

@a13821190779

maodapeng1 commented 7 years ago

仔仔细细看题的我,就这样错过了福利? @jawil

FoxDaxian commented 7 years ago

还是得打磨自己的技术啊

smackgg commented 7 years ago

websocket 拼错了。有我看的这么仔细的么哈哈哈😆

jawil commented 7 years ago

厉害了,老铁,这都被你发现了,我写文章单词大小写都很注意,没想到。。。暴露了我没怎么深入搞过websocket 😂@smackgg

ywwhack commented 7 years ago

数组去重其实可以这样写:

const exists = {}
;[1,2,3,1,'a',1,'a'].filter(item => {
  if (exists[item]) return false
  exists[item] = true
  return true
})

复杂度从 O(n2) -> O(n)

jawil commented 7 years ago

厉害了,看来老铁数据结构与算法功底深厚啊 @ywwhack

ywwhack commented 7 years ago

@jawil 我也是 16 年毕业的,面过阿里也是拿到一个外包 - -,历史总是惊人的相似

jawil commented 7 years ago

😂,看见外包就想笑,这个词已经成了贬义词,所以就没考虑了,一样的KPI考核,不一样的身份,不一样的待遇。@ywwhack

kevinaskin commented 7 years ago

@ywwhack const还可以赋值吗

jawil commented 7 years ago

注意看,是添加属性,不是断开指针重新指向一个内存指针,所以没毛病 @kevinaskin

kevinaskin commented 7 years ago

@jawil soga 学习了

leavecu commented 7 years ago

自愧不如啊,大哥您是怎么学的,指点一二嘛

jadetang commented 7 years ago

能来个邀请码吗,我可以帮你内推。

jawil commented 7 years ago

老司机这是要推到哪里去?最好带装逼带我我飞😂 @jadetang

Q-Zhan commented 7 years ago

能请教下师兄学习方向吗?我是在校大学生,已经有用vue全家桶和react全家桶做过几个小型的单页面应用,JS基础方面也很重视,现在应该如何进一步成长? @jawil

jawil commented 7 years ago

框架能够让我们跑的更快,但只有了解原生的JS才能让我们走的更远。我觉得吧,JS基础很重要,但是计算机体系很重要,不仅是JS基础吧,以后你的工作环境对你同样重要,决定你往哪方面深入了。总之,长话短说,见多才能识广,量变才能带来质变。一两句话也帮不到你什么,因为这是个因人而异的问题,自己能力有限,也在摸索,对于你该如何进一步成长,这个我不敢妄自指路,总而言之,好好学习,天天向上。好像说了几句废话,也算是一个答复吧,对于这种抽象的问题实在不好回答😂 @Q-Zhan

Q-Zhan commented 7 years ago

都说JS基础很重要,那对于JS基础这一块师兄你是怎么学的 @jawil

jawil commented 7 years ago

深入理解JavaScript系列 - 汤姆大叔 - 博客园

前端基础进阶系

深入理解javascript原型和闭包系列 - 王福朋 - 博客

mqyqingfeng/Blog

推荐几个自己收藏的深入学习JavaScript的博客。

@Q-Zhan

niuxiaokui commented 7 years ago

同是16年毕业,两年的工作经验是白瞎了.....啃书去