Skip to content

《前端内参》帮助前端工程师们夯实技术以通过一线互联网企业技术面试。日拱一卒,一年下来你会惊叹自己的进步。

License

Notifications You must be signed in to change notification settings

cy-biggray/frontend-hard-mode-interview

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

description
帮助前端工程师们夯实技术以通过一线互联网企业技术面试。日拱一卒,一年下来你会惊叹自己的进步。

前端内参

阅 读 本 书:https://coffe1891.gitbook.io/frontend-hard-mode-interview
Github仓库:https://github.com/coffe1891/frontend-hard-mode-interview

如果觉得有帮助,请点一下右上角的star;如果想和前端工程师们讨论,也可以加入QQ群。【QQ群】308689488,【微信】kenny2019 (加微信请注明 “前端内参”)。

  1. 本书较多着笔于深层理论上的论述,辅有代码示例,多是经过时间洗礼后的沉淀,适合至少三年前端工作经验的朋友阅读。然而前端技术日新月异,我也在不断学习,因此疏漏之处在所难免,欢迎朋友们随时@提建议,我将及时改进;
  2. 阅读本书尽量去上面的gitbook地址,gitbook导航更清晰,图片也不会出现显示错位;
  3. 如果书里文章的图片显示不了,开翻墙工具、或者多刷几遍就好。

前言

如何在Hard模式下通过一线互联网公司的面试?相信很多程序员朋友都有过这个困扰。其实答案很简单:首先应努力成为一个好的程序员,然后入职一线互联网公司只是顺路的事

然后你可能会吐槽:“前端知识已经爆炸,今天这个框架明天那个库的,天天有新玩意儿,我实在学不动了!”是的,前端知识早已大爆炸,新东西层出不穷,如果只是靠蛮力一样一样地去学习,那么连笔者我也学不动了😂 。怎么办呢?别慌,其实前端学习是有窍门的。本书归纳了前端的核心知识点,日拱一卒地坚持学习,系统地掌握这些知识点之后,相信很快你也能和我一样可以做到以不变应万变,以小变应大变,并对新的前端知识很快领悟、吃透!

作为一个老程序员,coding已经成为生命的一部分,coding到八十岁是我的理想,而JavaScript是我挚爱的语言。自从2010年出版个人第一本互联网技术书籍后,便再也没有时间可以写系统性论述技术的著作。因为后来加入奇虎360和百度这两家一线互联网公司,从事前端与手机客户端技术性工作,并主持研发了亿级用户的手机APP,这期间相当繁忙。而在进入360和百度之前,记得那年是2011年,创业公司彻底倒闭,我失业了。实在没办法,为了谋生打算找一份工作。当时是计划入职一线互联网公司,做感兴趣的前端(Front-End)coding。因为从大学出来后和师兄们折腾创业,虽有一些技术积累但是不够系统化,而且缺乏职业化的工作经历,求职时是有点尴尬的,一线互联网公司似乎不太乐意接受这种情况,面试之旅已然进入Hard模式。面对逆境,我希望通过用扎实的技术功底和丰富的实战经验来打动雇主。

在复习/学习期间,我查阅了大量国内外文档资料,发现原始资料相对少,原始的资料论文式偏多的,对英语阅读能力有非常大的挑战。而国内的资料大多数有错漏、不完整:首先是翻译问题非常大,术语翻译错误、译文表意模棱两可、原文内容翻译不完整,让人看了更加迷惑不解;国内网上的文章,绝大多数缺乏系统化论述,知识点分散零碎,而且很多有代码错误……各种原因,对自己的学习过程造成了不少困扰。

综上,感同身受求知之不易,因此多年后(2019年)有了闲暇便立即着手整理并分享本书,把当前前端核心知识要点梳理一遍,供前端工程师朋友们复习与进阶参考。

如果我能通过自身努力最终能达成入职一线互联网公司的目标,那么更年轻、更健康和更聪明的程序员朋友们只会做得更好。加油吧,奥力给!本书还正在持续更新中,许多章节会陆续“点亮”的 🧡 。

目录

零、准备Hard模式下的面试

  1. 一线互联网公司面试前的准备

壹、前端之灵:JavaScript/ECMAScript

  1. 你需要知道的新东西
  2. 核心概念
  3. 其他知识点
  4. 浏览器、V8引擎
    • 网页被浏览器绘出来过程是怎样的?
    • 页面重排(Reflow)与重绘(Repaint)
    • DOM、Shadow DOM、Virtual DOM updating…
    • V8引擎是如何工作的
    • V8引擎内存管理和垃圾回收机制
  5. 相关后端知识、通信协议、安全
  6. 书籍推荐
  1. 面试时高频率出现的算法
  2. 其他经典算法
  3. 好书推荐

叁、主流框架/库

  1. 综合比较
  2. React
  3. Vue.js
    • Vue.js源码解读:Vue数据响应式原理
    • Vue.js带来的一些新问题以及解决办法探索
  4. Angular.js
    • 你真的懂Angular.js吗?
    • Angular.js性能优化要点
  5. Flutter
    • 浅谈Flutter给前端研发带来的变化
    • Dart
  6. 好书推荐

肆、动效

  1. 动效应用的场景
    • 不要拒绝设计小姐姐的要求
    • 有效的引导用户
    • 让页面拥有生命力
  2. css3动画基础
  3. css3动画实践
    • 弹窗
    • 逐帧动画
    • 悬浮按钮
    • 广告动画
    • 3D动画
  4. canvas
    • 画布的基本功能
    • 分享到朋友圈的预览图制作
    • 飞机大战小游戏
  5. webgl
    • 3D的基础知识
    • 谁都会做的全景图
    • 3D跑酷小游戏

伍、必会的工具

  1. Webpack-自动打包模块工具
    • 深入理解Webpack打包
    • 常用的脚手架
  2. API文档管理
    • 用Swagger解决API文档更新的烦恼
  3. IDE-工欲善其事必先利其器
    • 高效使用VSCode的10点建议
    • 适用于前端开发者的20个VSCode插件
    • Sublime Text

陆、设计原则与编程范式

  1. 设计原则(SOLID)
  2. 面向对象编程(OOP)
  3. 函数式编程
  4. 响应式编程
  5. 好书推荐

柒、设计模式和软件工程

  1. 十四种经典设计模式
    • 单例模式
    • 策略模式
    • 代理模式
    • 迭代器模式
    • 发布-订阅模式
    • 命令模式
    • 组合模式
    • 模板方法模式
    • 享元模式
    • 职责链模式
    • 中介者模式
    • 装饰者模式
    • 状态模式
    • 适配器模式
  2. 浅谈软件工程:MVC、MVP、MVVM
    • MVC的前世今生 updating…
    • MVP又是什么?
    • 有了MVC和MVP,为什么还要MVVM?

捌、很有用的网站

  1. 中文站-Mozilla大宝库 外链 最全的Web相关参考文档,没有之一
  2. 英文站-StackOverflow 外链 掌握了四级英语就能向老外提问交流了,解决疑难杂症必上
  3. 中文站-Vue.js手册 外链 手册在手,玩转Vue不愁
  4. 英文-Vue资源大全 外链 超级多的资源,总能找到你喜欢的那款

玖、公众号&博客推荐

  1. 一线互联网公司官方前端公众号
  2. 知名前端人物

拾、后记

  1. 成为一个好的程序员远比找份好工作重要
  2. 2020年前端技术展望

贡献者

thales-jiang

联系我

Bob Ma

网名:Bob Ma
微信:kenny2019(加微信请注明“前端内参”)
Email:[email protected]
Github:https://github.com/coffe1891

对本书有任何疑问,欢迎联系我。

版权许可

本作品采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可,只要保持原作者署名和非商用,您可以自由地阅读、分享、修改本书。

About

《前端内参》帮助前端工程师们夯实技术以通过一线互联网企业技术面试。日拱一卒,一年下来你会惊叹自己的进步。

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%