面试内容
小米 - 小米应用商店(过)
一面
小米的面试官给人的感觉很亲切很真诚,是一个体验很不错的面试。
css 实现图片自适应宽高
讲 flex,手写出 flex 常用的属性,并且讲出作用
BFC 是什么
项目里面的前端鉴权是怎么实现的?
vue 里面的虚拟 dom 是怎么回事?
vue 双向绑定讲一讲
手写函数防抖和函数节流
讲讲常用的 es6 语法,比如 let、promise、class 等等
浏览器渲染过程,回流重绘等等,load、DOMContentLoaded 等等事件的触发顺序
从小米应用商店里面随便找了一个需求让我现场实现,写伪代码
二面
讲项目里面的鉴权和图片懒加载怎么实现的
讲 vue-lazyloader 的原理,手写伪代码
讲 express 框架的设计思想
线上日志是如何处理的
讲事件循环
讲 nodejs 的 eventEmitter 的实现
三面
讲项目里面做的事情
讲 vue 的响应式原理、依赖收集、监听数组、虚拟 dom 等等
讲 express 的中间件系统是如何设计的
现场从小米应用商店中找出一个需求现场实现,说思路,写关键的代码
四面
讲 vue-lazyloader 源码以及设计
使用 es5 实现 es6 的 class
websocket 握手过程
浏览器的事件循环和 nodejs 事件循环的区别
百思编程(过)
这个公司是猎头推荐的,一家初创公司,CEO 比较强势,也算比较有趣。
一面
跨域以及解决办法
手写一段小算法
JavaScript 的 sort 方法内部使用的什么排序?
二面
这一面是 CEO 面,主要问了我的职业规划等等问题,在我没有表现出很强的要去该公司的意愿后,直接给我送走了 …
ponyAI- 基础架构(过)
一面
讲项目里面干了啥
vue-lazyloader 怎么实现的
vue 的响应式系统、虚拟 dom
函数式编程
手写了一个算法题
二面
这轮面试时从美国打电话过来的,事后才知道是 Google 的前端 …
讲讲项目里面做了什么
vue 原理,和 react 的区别(其实我没怎么用过 react)
JavaScript 异步的处理方式,现场出了一个问题,使用 promise 实现
三面
讲项目模块规划、项目如何部署、如何优化等等
手写函数的防抖
手写一道算法题
四面
讲讲项目
手写一道算法题
洋钱罐(过)
一面
讲项目
前端持久化的方式、区别
vue-lazyloader 的原理
怎么配 webpack
手写 vue 双向绑定
讲 es6 的一些特性,并且现场出了几个代码片段,说结果
手写一道算法题
http 状态码
二面
讲项目
vue-router 的原理
项目中怎么用的 webpack,怎么优化
讲 express 的设计原理
手写一道算法题
创新奇智(过)
一面
讲项目
手动实现 parseInt
二面
这一面居然遇到了前同事 … 写了一些笔试题,问了一些问题
三面
讲 tcp/ip 网络层、三次握手,为什么不能两次握手
讲 vue 原理
手写一道算法题
猿辅导(跪)
猿辅导好像总共就一面,期间一些实现方式和面试官有争议(没有冲突)
一面
手写 vue 的 mixin 方法
手写 promise 的 all 方法
现场出了一个移动端的小需求
搜狐 - 垂直媒体部门(过)
一面
讲项目
项目里面用 nodejs 做了啥
抽取了哪些 vue 组件
二面
讲项目
手写实现 promise
腾讯 - 地图(跪)
腾讯两个部门面试都会先做一套笔试题,笔试题基本就是一些常见的前端问题以及算法题
一面
讲项目,对项目提了一些问题
怎么判断一个点是否在圆形内、正方形内
对笔试题
腾讯 - 天天快报(跪)
也是先做了一套笔试题,但是令人尴尬的是,面试官觉得我快排写错了,然而我只是在原地快排没有申请额外空间 …
对笔试题
没了
百度 - 百度云(过)
这个部门今年据说升为一级部门了,好像还挺不错的
一面
讲项目
vue 响应式原理,什么是 mvvm
es6 使用过的特性
flex 常见的属性
css 选择器的优先级
抽取过哪些 vue 组件
二面
讲项目
express 设计原理,面试官对动态路由匹配一直追问下去,但是这里的源码设计我确实是忘了,一路讨论下去扯到了字符串的前缀树 …
实现一个事件发布订阅类,其实就是 eventEmitter
三面
三面是山大老学长,聊了一些业务上的事情
搜狗 - 手机搜狗(过)
搜狗一面的体验比较差,面试官给人的感觉不太好 …
一面
讲项目
事件循环
回调函数的坏处
vue 里面哪儿不会用到双向绑定
二面
忘了 …
快手 - 商业化(过)
一面
讲项目
如何抽取公共组件的
vue 的响应式原理
如何实现一个可设置过期时间的 localStorage
实现一个发布订阅系统,包括 on、emit、off 等等
二面
一道智力题
软件工程思想、设计模式等等
async/await 代码片段,说输出结果
今日头条 - 广告系统(过)
一面
讲项目
讲 lazyloader 实现
用 docker 做了什么
用 webpack 做了什么
手写一个算法题
讲 flex
vue 响应式原理
es6
二面
JavaScript 异步
优化项目
vue 原理,包括计算属性、依赖收集等等
用 JavaScript 的异步实现 sleep 函数
算法题
三面
手写快排,时间复杂度,优化
手写实现 jsonp
项目部署,线上问题等等
websocket 握手过程
四面
对 vuex 的理解,单向数据流
设计一个单点登录的系统,类似阿里系那种
手写一个算法
五面
实现一个联想搜索组件
手写函数防抖和节流
OPPO 成都研发中心(过)
一面
讲项目
讲 vue 的 响应式系统,讲了好久,从渲染 watcher 到虚拟 dom,面试官还跟我讨论了好久
忘了
二面
讲项目
忘了
百词斩(跪)
首先会在线做一道算法题,挺简单的,百词斩感觉挂的稀里糊涂的 …
一面
websocket 握手过程
tcp/ip 网络层,http 的特点
http 强行使用 udp 能实现吗?
vue 原理
webpack 热更新原理,使用过的插件
原型、闭包、跨域
手写了一道算法题
为什么面这么多公司
因为我是实习直接转正的,也没参加过秋招,所以对自己在市场上是个怎样的实力没有一个清晰的了解,而且我也想多了解一下其他公司在做什么,于是就尽量的多面,不过说实话面试确实挺累的。
如何准备
首先前端基础要过关,可以参考前端工程师手册、合格前端系列第九弹 - 前端面试那些事、2018 前端面试押题(讲义)、Interview Book。其次,因为我是在小厂,所以可能项目复杂度没那么高,我就尽量把手头上用到过的东西都搞明白设计原理,比如 vue、express、vue-lazyloader、promise 等等,平时也会造一些轮子,其实这些对业务开发都是有好处的,起码可以让你知道自己在写啥。最后,计算机基础也是抛不开的,LeetCode 刷 200 题左右,常见的排序、搜索、树遍历算法都要会,而且以这几个为基础的变形也要能看出来。