你好,我是winter。今天我们一起来聊聊前端的学习路线与方法。
在“开篇词”中,我和你简单回顾了前端行业的发展,到现在为止,前端工程师已经成为研发体系中的重要岗位之一。可是,与此相对的是,我发现极少或者几乎没有大学的计算机专业愿意开设前端课程,更没有系统性的教学方案出现。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。
这样的现状就引发了一系列的问题。
首先是前端的基础知识,常常有一些工作多年的工程师,在看到一些我认为很基础的JavaScript语法的时候,还会惊呼“居然可以这样”。是的,基础知识的欠缺会让你束手束脚,更限制你解决问题的思路。
其次,技术上存在短板,就会导致前端开发者的上升通道不甚顺畅。特别是一些小公司的程序员,只能靠自己摸索,这样就很容易陷入重复性劳动的陷阱,最终耽误自己的职业发展。
除此之外,前端工程师也会面临技术发展问题带来的挑战。前端社区高度活跃,前端标准也在快速更新,这样蓬勃发展对技术来说无疑是好事,但是副作用也显而易见,它使得前端工程师的学习压力变得很大。
我们就拿JavaScript标准来说,ES6中引入的新特性超过了过去十年的总和,新特性带来的实践就更多了,仅仅是一个Proxy特性的引入,就支持了VueJS从2.0到3.0的内核原理完全升级。
缺少系统教育+技术快速革新,在这样的大环境下,前端工程师保持自学能力就显得尤其重要了。
那么,前端究竟应该怎么学呢?我想,我可以简单分享一下自己的经验。
学习路径与学习方法
首先是0基础入门的同学,你可以读几本经典的前端教材,比如《JavaScript高级程序设计》《精通CSS》等书籍,去阅读一些参考性质的网站也是不错的选项,比如MDN。
如果你至少已经有了1年以上的工作经验,希望在技术上有一定突破,那么,这个专栏就可以是你技术进阶的一个选项了。
在这个专栏中,我希望传达的不仅仅是具体的知识点,还有体系架构和学习方法。我希望达到三个目标:
- 带你摸索出适合自己的前端学习方法;
- 帮助你建立起前端技术的知识架构;
- 让你理解前端技术背后的核心思想。
在开始具体的知识讲解之前,这篇文章中,我想先来谈两个前端学习方法。
第一个方法:建立知识架构
第一个方法是建立自己的知识架构,并且在这个架构上,不断地进行优化。
我们先来讲讲什么叫做知识架构?我们可以把它理解为知识的“目录”或者索引,它能够帮助我们把零散的知识组织起来,也能够帮助我们发现一些知识上的盲区。
当然,知识的架构是有优劣之分的,最重要的就是逻辑性和完备性。
我们来思考一个问题,如果我们要给JavaScript知识做一个顶层目录,该怎么做呢?
如果我们把一些特别流行的术语和问题,拼凑起来,可能会变成这样:
- 类型转换;
- this指针;
- 闭包;
- 作用域链;
- 原型链;
- ……
这其实不是我们想要的结果,因为这些知识点之间,没有任何逻辑关系。它们既不是并列关系,又不是递进关系,合在一起,也就没有任何意义。这样的知识架构,无法帮助我们去发现问题和理解问题。
如果让我来做,我会这样划分:
- 文法
- 语义
- 运行时
为什么这样分呢,因为对于任何计算机语言来说,必定是“用规定的文法,去表达特定语义,最终操作运行时的”一个过程。
这样,JavaScript的任何知识都不会出现在这个范围之外,这是知识架构的完备性。我们再往下细分一个层级,就变成了这个样子:
- 文法
- 词法
- 语法
- 语义
- 运行时
- 类型
- 执行过程
我来解释一下这个划分。
文法可以分成词法和语法,这来自编译原理的划分,同样是完备的。语义则跟语法具有一一对应关系,这里暂时不区分。
对于运行时部分,这个划分保持了完备性,我们都知道:程序 = 算法 + 数据结构,那么,对运行时来说,类型就是数据结构,执行过程就是算法。
当我们再往下细分的时候,就会看到熟悉的概念了,词法中有各种直接量、关键字、运算符,语法和语义则是表达式、语句、函数、对象、模块,类型则包含了对象、数字、字符串等……
这样逐层向下细分,知识框架就初见端倪了。在顶层和大结构上,我们通过逻辑来保持完备性。如果继续往下,就需要一些技巧了,我们可以寻找一些线索。
比如在JavaScript标准中,有完整的文法定义,它是具有完备性的,所以我们可以根据它来完成,我们还可以根据语法去建立语义的知识架构。实际上,因为JavaScript有一份统一的标准,所以相对来说不太困难。
如果是浏览器中的API,那就困难了,它们分布在w3c的各种标准当中,非常难找。但是我们要想找到一些具有完备性的线索,也不是没有办法。我喜欢的一个办法,就是用实际的代码去找:for in 遍历window的属性,再去找它的内容。
我想,学习的过程,实际上就是知识架构不断进化的过程,通过知识架构的自然延伸,我们可以更轻松地记忆一些原本难以记住的点,还可以发现被忽视的知识盲点。
建立知识架构,同样有利于面试,没人能够记住所有的知识,当不可避免地谈到一个记不住的知识,如果你能快速定位到它在知识架构中的位置,把一些相关的点讲出来,我想,这也能捞回不少分。(关于前端具体的知识架构,我会在02篇文章中详细讲解。)
第二个方法:追本溯源
第二个方法,我把它称作追本溯源。
有一些知识,背后有一个很大的体系,例如,我们对比一下CSS里面的两个属性:
- opacity;
- display。
虽然都是“属性”,但是它们背后的知识量完全不同,opacity是个非常单纯的数值,表达的意思也很清楚,而display的每一个取值背后都是一个不同的布局体系。我们要讲清楚display,就必须关注正常流(Normal Flow)、关注弹性布局系统以及grid这些内容。
还有一些知识,涉及的概念本身经历了各种变迁,变得非常复杂和有争议性,比如MVC,从1979年至今,概念变化非常大,MVC的定义几乎已经成了一段公案,我曾经截取了MVC原始论文、MVP原始论文、微软MSDN、Apple开发者文档,这些内容里面,MVC画的图、箭头和解释都完全不同。
这种时候,就是我们做一些考古工作的时候了。追本溯源,其实就是关注技术提出的背景,关注原始的论文或者文章,关注作者说的话。
操作起来也非常简单:翻翻资料(一般wiki上就有)找找历史上的文章和人物,再顺藤摸瓜翻出来历史资料就可以了,如果翻出来的是历史人物(幸亏互联网的历史不算悠久),你也可以试着发封邮件问问。
这个过程,可以帮助我们理解一些看上去不合理的东西,有时候还可以收获一些趣闻,比如JavaScript之父 Brendan Eich 曾经在Wikipedia的讨论页上解释JavaScript最初想设计一个带有prototype的scheme,结果受到管理层命令把它弄成像Java的样子(如果你再挖的深一点,甚至能找到他对某位“尖头老板”的吐槽)。
根据这么一句话,我们再去看看scheme,看看Java,再看看一些别的基于原型的语言,我们就可以理解为什么JavaScript是现在这个样子了:函数是一等公民,却提供了new this instanceof等特性,甚至抄来了Java的getYear这样的Bug。
结语
今天我带你探索了前端的学习路径,并提出了两个学习方法:你要试着建立自己的知识架构,除此之外,还要学会追本溯源,找到知识的源头。
这个专栏中,我并不奢望通过短短的40篇专栏,事无巨细地把前端的所有知识都罗列清楚,这本身是MDN这样的参考手册的工作。但是,我希望通过这个专栏,把前端技术背后的设计原理和知识体系讲清楚,让你能对前端技术产生整体认知,这样才能够在未来汹涌而来的新技术中保持领先的状态。
在你的认识中,前端知识的结构是怎样的?欢迎留言告诉我,我们一起讨论。
精选留言
2019-01-17 02:49:45
2019-01-17 09:35:08
2019-01-17 03:18:57
前端 = HTML + CSS + JavaScript
每种语言下,又混杂了基础知识以及相关的工具。
比如我之前认为的 JavaScript 包括:
* JavaScript 基础
* Package Manager (NPM, Yarn)
* Build tools (NPM Scripts, ESLint, Webpack...)
* Frameworks (React, Vue.js, Angular)
* Testing tools (Jest ...)
现在知道自己的认识有两个误区:
1. 这个知识架构没有完备性,这样划分,总有在这个结构之外的知识;
2. 学习的时候会疲于奔命,总想“完整”的学完所有的知识,却走了弯路。
感谢 winter 老师。
2019-01-17 23:02:56
2019-01-17 08:15:14
就算不会,坐下来花一天时间看看MDN几乎都能写出来了
我们都知道写HTML要语义化,但是HTML5的语义我感觉非常复杂
有多少人能保证写出来的网页完完全全遵循了正确的语义?
能达到屏幕阅读器理解的程度?
我们想写语义正确的网页,但是也不想被语义复杂性所拖累(本来读的也不是文科,div一分钟能写出来的东西在语义上要纠结好久)
程老师,我的问题是,作为一名前端工程师,平常工作的时候写HTML究竟要语义化到哪种程度呢?
2019-01-17 10:59:06
2019-01-17 09:33:00
2019-01-17 08:35:51
https://github.com/kamranahmedse/developer-roadmap/blob/master/readme.md
winter老师第一种建立知识架构的方式,更像是做了进一步抽象。
2019-01-17 08:57:36
1.1.1,资源加载
1.1.2,webpack打包
1.1.3,摇树优化
1.2,网络传输,因为传统上是浏览器发起页面请求,然后服务器端发送html页面。
1.2.1,资源加载
1.2.2,首屏页面加载优化
1.3,浏览器端的页面渲染。
1.3.1,浏览器如何渲染一张html页面
1.3.2,渲染性能优化
1.4代码编写
1.4.1,html页面架构
1.4.1.1 .....
...
1.4.2,css页面样式
1.4.2.1, ......
.....
1.4.3,js交互
1.4.3.1,.....
.....
2019-01-17 01:02:16
感觉 winter 叔这篇主要是站在非科班出身或半路出家的前端从业者的角度来看的,确实我刚开始接触前端这一陌生领域来说就是这样,没有知识体系,都是知识点拼接的一张记忆网络,很多点觉得不可思议,难以记忆。实际是上不了解本质,不了解来龙去脉,所以很多知识在脑海中就不够形象。
期待接下来 winter 的思路!
2019-04-21 11:05:00
首先,前端项目的搭建要合理清晰,
其次,组件的复用性,最好的组件方式就是只负责UI层面的渲染,不涉及业务,业务抽离出来做成service等;而且组件最好细小化,只负责一小块,
然后,页面尽量语义化,scss,sass尽量少,能全局的放在全局,比如Mixin, normalize,当设计变来变去,也要和设计师沟通协商调整,不可能他今天一个样式,明天换一个,
接着,组件,service什么的写完了,确保自己代码测试覆盖率,记得写unit test,可以向别人下保票,自己写的99%是没问题的,如果别人想来challenage你代码,也会理直气壮有理有据。
尽量减少自己的代码量,html css js文件,
业界有很多成熟的框架,结合自己的业务,结合项目要求,能用的就用,时间精力思考广度,远远优于自己去手写一个,不然很容易会出现各种各样的问题和bug,
用别人的框架,有时间就了解一下原理,看看源码啥的,知其然也要知其所以然,面试也有帮助,加身功能理解,以后业务方面也会更清晰,
然后呢,肯定任何人写的代码都有值得优化的,要有这个思想存在,想着变得更好,
还有其他的细节吧,先这样啦,个人体会就是这样啦,也是在每天进步,观察,思考,实践,层层递进,
2019-02-14 14:46:29
前端发展到现在,无论是jquery时代,还是现在三大框架,还是说vue in all的时代,归根结底这些工具的产生都是为了解决工作效率等问题。结合现在互联网行业的发展来看,后期的前端生存之道可能更多的是思考如何把前端当成一个应用来做,不仅仅局限于网页。而应用可能要思考的是易用性,可扩展性,可维护性,甚至可移植性,那么这一切都需要夯实的基础来支撑。
2019-02-13 10:18:51
https://docs.itellboy.wang/es5/
共勉
2019-01-17 11:12:55
2019-01-21 23:46:44
2019-01-17 00:43:25
2019-01-18 17:02:55
1.html 骨架
2.css css3 外观
3.js 行为
4.浏览器(
1.插件 草料二维码 vue dectools这类
2.http协议
3.工具 network console...
4.window对象等
5.兼容
6.渲染模式)
5.工具(
1.编辑器 webstorm vscode hbuilder
2.git/webpack
6.框架(vue react...
7.插件库/ui库(axios moment 富文本编辑器 element antd
大概就是这个样子吧..
希望可以看到后面的课程取精华去糟粕有所进步
2019-01-17 09:04:31
加油加油!!!
2019-01-17 22:53:42
又重新复习了一遍今天的内容:学习路径和学习方法。
学习路径就是看书和建设性网站,购买老师的专栏,我觉得看不错的视频教程也是一种路径。
学习方法就是搭建知识架构和追本溯源。
老师讲解的学习方法都是三个维度(what、how、why)一步步由浅入深,从概念到方法再到收获,逻辑清晰同时具有完备性。
我是做 iOS 开发,知识架构是通过印象笔记中 iOS 功能知识点划分的笔记本加标签共同构建的目录和索引。学习了老师的方法之后,后面重新思考再梳理一下有逻辑具有完备性的知识体系吧。
2019-01-17 10:01:30