4.3 扎实的技术储备与工程能力
接下来是整个面试中90%时间在干的事情,也就是对你的技术储备与工程能力的考核。
一般来说,大厂的前端校招会比其他中小企业更看重对面试者的全方位考核,如果你是科班出身,校招的技术考核会包括且不限于:
-
计算机专业基础(数据结构,算法,计算机网络,操作系统,数据库)
-
职位相关基础(JS/ES知识体系,浏览器渲染与缓存,前后端通信,Web安全)
-
工程实践经验(性能优化,依赖管理,依赖打包,模块化,组件化,用户鉴权,版本管理,包管理,服务器基础)
-
主流框架理解(Vue,React二选一)
-
部分要求极高的大厂还会考核你的理科基础(线性代数,高等数学)
另外,不同的大厂也有不同的侧重点。
技术实力最顶尖的阿里淘系FED会对你的基础知识体系以及你简历上写到的技能展开一场惨绝人寰的刨根问底,而字节跳动则更看重你的实际工程经验以及对于软件系统架构的理解。
通过每家大厂的面试策略,你也可以侧面观察出这家企业的团队技术实力和业务发展方向。
我将技术面中遇到的所有知识点整理成了一张思维导图。建议一条一条仔细查阅,对于任何没有百分百把握的知识点,我都建议你把它整理到一个列表里,逐条梳理。
由于图片太大,完整版脑图可以【点击我】免费分享。
4.4 职业规划
如果你通过了以上所有考核的话,恭喜你,你离获得offer基本只剩一步之遥了。
一般到这个时候,面试官会问你对自己的职业规划。
这个问题其实也是需要自己问题自己的,最好在投递简历的时候就想清楚:
-
为什么要去这家企业,看中它哪方面的优势(业务,技术,平台,前景)
-
我为什么要应聘这个岗位,我对自己未来的发展方向有什么样的期许(能力,职位,技术栈,行业)
还是那句话 —— 不想当架构师的前端不是好程序员(雾)。
4.5 每次结束后一定要复盘总结
如果面试没有复盘,你参加再多的面试也和没有参加一样。不要叹息面试中出的洋相或者咒骂面试官有多么反人类,不管多么受伤都要在面试结束后立刻复盘。
现场面试最好一出场就开始回忆面试流程&写备忘录,如果是电话面试可以录音下来重听一边,捋一捋面试官的问题和自己的回答,看看自己答得如何(答成了什么b样),有没有可能答得更好。
下面分享的面试题,有我自己去面试遇到的,也有我到网上刷题时刷到的,我都做了一个整理,
HTML
-
HTML5新特性,语义化
-
浏览器的标准模式和怪异模式
-
xhtml和html的区别
-
使用data-的好处
-
meta标签
-
canvas
-
HTML废弃的标签
-
IE6 bug,和一些定位写法
-
css js放置位置和原因
-
什么是渐进式渲染
-
html模板语言
-
meta viewport原理
CSS
-
盒模型,box-sizing
-
CSS3新特性,伪类,伪元素,锚伪类
-
CSS实现隐藏页面的方式
-
如何实现水平居中和垂直居中。
-
说说position,display
-
请解释*{box-sizing:border-box;}的作用,并说明使用它的好处
-
浮动元素引起的问题和解决办法?绝对定位和相对定位,元素浮动后的display值
-
link和@import引入css的区别
-
解释一下css3的flexbox,以及适用场景
-
inline和inline-block的区别
-
哪些是块级元素那些是行级元素,各有什么特点
-
grid布局
-
table布局的作用
-
实现两栏布局有哪些方法?
-
css dpi
-
你知道attribute和property的区别么
-
css布局问题?css实现三列布局怎么做?如果中间是自适应又怎么做?
-
流式布局如何实现,响应式布局如何实现
-
移动端布局方案
-
实现三栏布局(圣杯布局,双飞翼布局,flex布局)
-
清除浮动的原理
-
overflow:hidden有什么缺点?
-
padding百分比是相对于父级宽度还是自身的宽度
-
css3动画,transition和animation的区别,animation的属性,加速度,重力的模拟实现
-
CSS 3 如何实现旋转图片(transform: rotate)
-
sass less
-
对移动端开发了解多少?(响应式设计、Zepto;@media、viewport、JavaScript 正则表达式判断平台。)
-
什么是bfc,如何创建bfc?解决什么问题?
-
CSS中的长度单位(px,pt,rem,em,ex,vw,vh,vh,vmin,vmax)
-
CSS 选择器的优先级是怎样的?
-
雪碧图
-
svg
-
媒体查询的原理是什么?
-
CSS 的加载是异步的吗?表现在什么地方?
-
常遇到的浏览器兼容性问题有哪些?常用的hack的技巧
-
外边距合并
-
解释一下“::before”和“:after”中的双冒号和单冒号的区别
JS
-
js的基本类型有哪些?引用类型有哪些?null和undefined的区别。
-
如何判断一个变量是Array类型?如何判断一个变量是Number类型?(都不止一种)
-
Object是引用类型嘛?引用类型和基本类型有什么区别?哪个是存在堆哪一个是存在栈上面的?
-
JS常见的dom操作api
-
解释一下事件冒泡和事件捕获
-
事件委托(手写例子),事件冒泡和捕获,如何阻止冒泡?如何组织默认事件?
-
对闭包的理解?什么时候构成闭包?闭包的实现方法?闭包的优缺点?
-
this有哪些使用场景?跟C,Java中的this有什么区别?如何改变this的值?
-
call,apply,bind
-
显示原型和隐式原型,手绘原型链,原型链是什么?为什么要有原型链
-
创建对象的多种方式
-
实现继承的多种方式和优缺点
-
new 一个对象具体做了什么
-
手写Ajax,XMLHttpRequest
-
变量提升
-
举例说明一个匿名函数的典型用例
-
指出JS的宿主对象和原生对象的区别,为什么扩展JS内置对象不是好的做法?有哪些内置对象和内置函数?
-
attribute和property的区别
-
document load和document DOMContentLoaded两个事件的区别
-
=== 和 == , [] === [], undefined === undefined,[] == [], undefined == undefined
-
typeof能够得到哪些值
-
什么是“use strict”,好处和坏处
-
函数的作用域是什么?js 的作用域有几种?
-
JS如何实现重载和多态
-
常用的数组api,字符串api
-
原生事件绑定(跨浏览器),dom0和dom2的区别?
-
给定一个元素获取它相对于视图窗口的坐标
-
如何实现图片滚动懒加载
-
js 的字符串类型有哪些方法? 正则表达式的函数怎么使用?
-
深拷贝
-
编写一个通用的事件监听函数
-
web端cookie的设置和获取
-
setTimeout和promise的执行顺序
-
JavaScript 的事件流模型都有什么?
-
navigator对象,location和history
-
js的垃圾回收机制
-
内存泄漏的原因和场景
-
DOM事件的绑定的几种方式
-
DOM事件中target和currentTarget的区别
-
typeof 和 instanceof 区别,instanceof原理
-
js动画和css3动画比较
-
JavaScript 倒计时(setTimeout)
-
js处理异常
-
js的设计模式知道那些
-
轮播图的实现,以及轮播图组件开发,轮播10000张图片过程
-
websocket的工作原理和机制。
-
手指点击可以触控的屏幕时,是什么事件?
-
什么是函数柯里化?以及说一下JS的API有哪些应用到了函数柯里化的实现?(函数柯里化一些了解,以及在* 函数式编程的应用,最后说了一下JS中bind函数和数组的reduce方法用到了函数柯里化。)
-
JS代码调试
框架
-
使用过哪些框架?
-
zepto 和 jquery 是什么关系,有什么联系么?
-
jquery源码如何实现选择器的,为什么$取得的对象要设计成数组的形式,这样设计的目的是什么
-
jquery如何绑定事件,有几种类型和区别
-
什么是MVVM,MVC,MVP
-
Vue和Angular的双向数据绑定原理
-
Vue,Angular组件间通信以及路由原理
-
react和vue的生命周期
-
react和vue的虚拟dom以及diff算法
-
vue的observer,watcher,compile
-
react和angular分别用在什么样的业务吗?性能方面和MVC层面上的区别
-
jQuery对象和JS的Element有什么区别
-
jQuery对象是怎么实现的
-
jQuery除了它封装了一些方法外,还有什么值得我们去学习和使用的?
-
jQuery的$(‘xxx’)做了什么事情
-
介绍一下bootstrap的栅格系统是如何实现的
浏览器相关
-
跨域,为什么JS会对跨域做出限制
-
前端安全:xss,csrf…
-
浏览器怎么加载页面的?script脚本阻塞有什么解决方法?defer和async的区别?
-
浏览器强缓存和协商缓存
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
最后
四轮技术面+一轮hr面结束,学习到了不少,面试也是一个学习检测自己的过程,面试前大概复习了 一周的时间,把以前的代码看了一下,字节跳动比较注重算法,面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~
祝大家都能收获大厂offer~
篇幅有限,仅展示部分内容
面试前刷了下leetcode和剑指offer, 也刷了些在牛客网上的面经。大概就说这些了,写代码去了~
祝大家都能收获大厂offer~
篇幅有限,仅展示部分内容