我的web前端面试心法(已拿字节offer)

前言

我的秋招经历

基本情况:
南方普通985普通学生,接触前端十个月左右,今年 8 月后开始正式准备秋招。

说起我的秋招,一个词,就是“逆袭”。一开始,华为笔试没过,三七互娱笔试没过被捞起来后一面又挂,信心受挫。中间没有再继续投递,而是沉下心准备,身边同学陆续拿到offer,也挺纠结。在十月底,赶在秋招的尾巴,投了四五家网申还没截止的公司,没想到,面试一路过,最后成功上岸字节,结束秋招。

准备面试和参加面试的过程中,总结了一些个人经验,梳理一下,希望对准备面试的人有些帮助,尤其是没有面试经历的学生。这里不谈及具体的面试题目,而是一些通用的方法论。

此文纯个人想法,希望读者保持自己的判断。

1、抛开面试,系统学习

在一切之前,应该系统地去学习前端的基础知识。 对前端而言,这些基础包括 HTML,CSS,JavaScript,浏览器原理,网络协议,MVVM 框架和一些必要的计算机基础等。应该先抛开面试的目的去学习这些知识,建立自己的知识体系,然后再结合面试题,运用掌握的知识去理解并解决面试题。

然而,很多人为了应付面试,基础技能掌握不扎实,就盲目地从网上查找各种面经,记忆甚至背诵各种面试题,本末倒置。

这里,推荐一些系统学习的途径和方法。


路线图

MDN文档:

每个Web开发人员必备,很权威很齐全的Web开发文档。作为学习辞典使用,可以查询到每个概念、方法、属性的详细解释,注意使用英文关键字搜索。里面的一些 HTML,CSS,HTTP 技术教程也相当不错。

HTML 和 CSS:

html5知识
css基础知识

推荐结合 MDN文档 和 W3school 两个线上教程,体会把玩上面的示例。这部分没有什么难度,主要在于记忆和编码实践,加深印象。

JavaScript

前端的重头戏,值得花大部分时间学习。

JavaScript知识

推荐通过书籍学习,《 JavaScript 高级程序设计(第 4 版)》你值得拥有。整本书内容质量都很高,尤其是前十章语言基础部分,建议多读几遍。

前端电子书

另外,大推一个网上教程 现代 JavaScript 教程 ,文章深入浅出,很容易理解,上面的内容几乎都是重点,而且充分发挥了网上教程的时效性和资料链接。

学习资料在精不在多,二者结合,定能构建你的 JavaScript 知识体系。

官方文档

一些框架和工具的学习,一定要充分利用官方文档,一般都会有快速上手的教程。因为这些版本更新很快,有些书籍跟文章的部分内容已经不适用了。建议从官方文档入手,不懂的地方 Google 一下。

博客文章

把博客放在最后,是因为它不适合系统学习,更适合单点强化,此时你应该拥有自己知识框架后,并且清楚文章内容的知识点。

2、注重基础,不要盲目学习框架

我在准备面试的时候,在 JavaScript 上花费了大量的时间。在学习 Vue 的时候,觉得很轻松,文档上很多东西都能理解。

不要急于学习框架和工具,把基本的 HTML,CSS,JavaScript 写熟练了。 运用原生技术,写一些基础的页面或组件,框架和工具最终也是通过这三大基础技术实现。

框架也是建立在原生技术之上的,扎实的基础能让你在学习框架时畅通无阻。比如,Vue 指令本质上是 HTML 元素特性;Vue 2.x 响应式原理是 JavaScript 的访问器属性的应用,Vue 3.0 采用了 ES6 新增语法 Proxy。如果你熟悉 JavaScript ,自然能明白 Vue 2.x 在对象与数组上的响应缺陷和 Vue 3.0 的改进意义。


vue

盲目学习框架,容易陷入为了框架而框架的误区。只有经历繁琐的原生 DOM 操作,你才能明白为什么提出 write less, do more 的 jQuery 曾风靡一时。只有经历一手操作数据一手操作视图的工作流,你才能体会 MVVM 数据驱动开发的强大之处。理解框架和工具的意义,而不是因为别人用了这个技术,所以你也要用,最后给项目添加不必要的复杂度。

从面试官的角度看,一个框架不熟悉的人,可能是开发经验稍欠,而一个基础不扎实的人,很大程度学习能力不强。这种看法,在校招,尤其是大厂的校招,尤为突出,因为公司更注重的是学生的可培养性。

3、精准出击,逐个击破面试题考点

面试本质也是考试,面试题就起到很好的考纲作用。想要取得优秀的面试成绩,刷面试题是必须的,除非你样样精通。

这是288页的前端面试题

288页面试题

当然我也刷了字节题,由于篇幅的原因就不贴图了,想要的可以可以继续看下去~
在看面试题的时候,应该从面试题发现考点,然后深入学习考点相关的知识,千万不要陷入背题的误区。毕竟题目是多变的,但考点相对固定。

兼听则明,偏听则暗。 对于网上看到的各种面试题答案,应该思考是否正确可行,是否还有改进的地方。大部分博客对知识点的总结无法做到完全全面。所以,我对很多考点,我都会 Google 一下,结合多篇文章,然后总结出自己的答案。

4、面试是一种输出

很多人刷了很多面试题,看了很多面经,知识储备充分,但面试的时候,即使是自己熟悉的考点,也很难令面试官满意。其关键原因在于,学习是一种输入,但面试是一种输出。

面试需要的不是你懂,而是要让面试官知道你懂,你必须有能力将考点中的要点联系起来,连贯的说出来,这并不是看过一次就能达到的。但不少人以为看过这类文章,知道这个点,就可以了。事实上,只是“知道”远远不够。

这种问题,根本上,是对技术点的不够深入,不够熟悉,没有形成自己的理解。我也经历过这一过程,你知道这些概念,自己也能分清,但难以向别人讲明白。简单测试一个CSS问题:什么是BFC? 你肯定知道叫块级格式化上下文,问题是,怎么向面试官解释这个东西?

为了解决这个问题,首先,学习过程注重理解而不是记忆。

第二,一个知识点,需要通过多篇文章学习,重复学习,加深理解,总结出自己的答案和看法。

第三,刻意练习。如果你有伙伴,可以相互提问。如果没有,也可以自问自答。

5、注重表达逻辑

如果上一点是说能正确回答问题,这点则是能更好的回答问题。一个逻辑清晰的回答,能让面试官感受到,面前的小伙子不仅熟悉这个问题,还有比较优秀的语言能力和逻辑能力。

比如,常见问题:说说 var, let/const 的区别。大部分人都能罗列出它们的区别和注意点,但这很难给面试官留下什么印象。但是,如果你添加几句联系性的语句,效果就不一样了:

var是 ES5 之前的变量声明方式,存在很多容易产生误解的缺陷,具体体现在:……(罗列 var 的一些不足), 针对这些问题,ES6 提出了 let/const 的变量声明方式,它们具有一些新的特性:……(罗列 let/const 特性)。

这几句简单的连接,让整个回答从一个简单的要点堆砌变成关系密切的表达。

然而,这并非易事。前提是必须要有较好的逻辑思维,既然选择这行,相信各位这点没有问题。

在学习每一个技术点的时候,都要注意一些问题:是什么?为了解决什么问题?如何实现的,有没有更深的原理?如何使用?使用的时候需要注意什么?有哪些应用的场景?有什么不足?这些不足能否避免? 这些问题能让你更加全面地体会各个问题的联系。

需要指出一点,写博客对这方面有很大的帮助。

即使你没有写过博客,建议在备考的时候,使用思维导图等工具,并且经常整理已学知识的联系。

可能有人跟我一样面试会紧张,一紧张就容易脑子空白。我的方法是,把面试官假想成是来请教我问题的同学,不得不说这种效果真的很好。(面试官表示老子懂的比你多了去了hh)

6、扬长避短,但尽量争取

对于那些每个应聘者必备的技能,必须要熟悉再熟悉,不要让基础成为自己的短板,切合上一条注重基础。而对于其它技能,深入学习其中的几个,然后想办法引导面试官提问这些方面的问题。

最有效最常见的引导方式是简历。简历信息往往是面试官出题的依据,所以简历一定不要写自己没接触过的技术,即使招聘信息有这项要求,如果面试官提问简历上的内容,发现你根本不会,那么,你简历上的所有技能点,面试官都会打个问号。对于你有深入学习的方面,可以单点列出,比如,熟悉 JavaScript,能熟练操作 DOM,尽管 JavaScript 包含了 DOM,但你依然可以强调一下。

面试官往往会根据应聘者的回答来决定下一个问题,我们也可以利用这点,在面试回答中引导。在回答开放性问题时,这种方法十分有效,但切记点到为止,不要过分深入导致偏题。比如,面试官提问:对一个已有的网站,你哪些的性能优化方案? 当你阐述性能改进提议之后,末了,加一句“除了性能,一个网站考虑还可以从安全性和 SEO 这些方面进行优化”。如果面试官 Web 安全和 SEO 感兴趣,那他就中套了。

如果面试官抛出了一个你稍有了解但不熟悉的问题。不要慌,先思考片刻。整合自己知道的,做一些合理的推测。然后在回答的时候,先表明自己不是很熟悉,但在学习其他知识的时候有接触过,简单说说自己的了解和推断。不少面试官会故意提出一些稍微超出面试者能力的问题,考量面试者的临场能力和迁移学习能力。

万一,明确面试官问题后,发现自己丝毫不会,直接表明,把面试官的注意力转移到下一道题,停留的时候长了,可能会放大这道题的影响。从容应对接下来的题目,面试官不会因为一两道题淘汰一个各方面都很优秀的面试者。

我目前是在职前端开发,如果你现在也想学习前端开发技术,在入门学习前端的过程当中有遇见任何关于学习方法,学习路线,学习效率等方面的问题,你都可以申请加入我所在的前端学习交流裙:前面:42137 后面:4697。里面聚集了一些正在自学前端的初学者,转行者,初阶者,文章内包含的内容,余下的字节题,感兴趣的可以点此获取~

7、后话

对于面试,说几句个人观点。

面试,说到底是一种考试。正如我们一直批判应试教育脱离教育的本质,为了面试学习技术也脱离了技术的初心。但考试对于人才选拔的有效性是毋庸置疑的,几千年来一直如此。除非你有实力向公司证明你足够优秀,否则,还是得乖乖准备面试。这也并不妨碍你在通过面试之后按自己的方式学习。

其实在面试准备阶段,个人的收获是很大的,我也认为这是一种不错的学习方式。首先,面试问题大部分基础而且深入,这些是平时工作的基础。就好像我们之前一直不明白学习语文的意义,但它的意义就在每天的谈话间。

所谓面试造火箭,工作拧螺丝。面试往往有更高的要求,也迫使我们更专心更深入地去学习一些知识,也何尝不是一种好事。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351

推荐阅读更多精彩内容