零基础的前端开发初学者应如何系统地学习?

前端变化太快,以下内容我会不定期更新,一年至少一次,持续做到2021年8月30日,刚好满十年。第三方网站请不要转载,如果实在想转载,请只转载摘要,并保留原文链接,谢谢。
发布于2011年8月30日
最后更新时间:2019年4月21日 00:42

在正文开始前,我还是先说一下我个人对于前端职业发展前景的看法。希望对那些站在前端学习起点,或者已经在路上,但犹豫不决的同学有所启发。

总的来说,到了2019年,初级前端在市场上是供大于求的,而高级前端依然是供小于求。这个判断主要是通过这些年面试的情况来看,没有全面的数据支撑,仅代表我个人观点。

初级前端供大于求。在培训机构和互联网公司的共同推动下,市场的初级前端很多。相比我2011年回答这个问题时,互联网公司在前端工程师的招聘要求高了很多。我毕业那年只是在学校里做了一个“图书管理系统”,边做边学搞了4个月,就可以拿到百度、淘宝的offer,而如今能做到这一点的候选人实在太多了。

高级前端供小于求。本质上因为互联网公司的发展速度高于市场上的前端工程师的平均成长速度。所以,虽然新手多了,企业招人依然困难。比如,天猫消费者端的导购页面,为了提高购买转化率,这些年来,在导购效率、用户体验维度做了非常多系统级体验优化方案,复杂度很高;又比如,阿里巴巴供应链平台,为了构建一套适用于阿里所有零售场景的供应链解决方案,同样在系统架构、用户体验、体验与研发效率的平衡等维度做了大量封装、抽象。这些是企业的高速发展的必然结果,然而市场上能够满足这样场景的同学,真的不容易找。

所以,到了2019年,那些打算通过这篇文档,开始自己前端职业生涯的同学,我希望大家,在起点处就做好了从初级跨入高级的准备。为了验证自己是否真的准备好了,可以尝试反复问自己这这个问题:你是否真的对前端感兴趣?至少说出3个能说服自己的理由。(如果是因为不喜欢现在工作,又听说前端简单才来学的,可以掉头回去了)。


一、前端通用学习方法

前端开发上手快,又容易得到反馈(页面效果是可见的),我推荐学习一点内容后快速实战,在实战中找到成就感,发现问题,然后再带着问题回去系统学习,如此往复。

二、基础

html + css

这部分建议在 w3school 在线教程 上学习,边学边练,每章后还有小测试。 学习过程中请打开chrome浏览器调试工具,直接命令行在内做些练习。

javascript

要学的内容实在很多,如果没有其他编程语言的基础的话,学起来可能要费些力,还是建议先在 w3school上学习。之后建议马上看《javascript语言精粹》,js是一门很混乱的语言,这本书能够帮助你区分哪些是语言的精华,哪些是糟粕,对于语言精华,应该深入学习。糟粕部分能看懂别人写的代码就行,自己就不用尝试了。

对于习惯看视频学习的同学,以上内容也可以在 慕课网-国内最大的IT技能学习平台 上学习。虽然我没用过,但好几位同学推荐过了,大概看了下,内容还不错。

数据结构和算法(2019年4月新增)

正如开篇的分析,目前市场缺的是高级前端,初级到高级的门槛不在未来,而是在过去的大学基础课。

前端为什么要学这些?因为这些都是稍微复杂一点的场景解决问题的必备武器。比如,把一个列表形式的地址数据,以树形渲染到页面,或者反过来;又比如,把一个多级嵌套的数据对象,转化成扁平的map结构再提交到服务器。更关键的,数据结构和算法,是计算机的思维方式,尤其是分治递归的思想,影响到代码实现、模块设计、乃至到系统设计。

三、初级

有了以上基础,就可以进行一般的静态网页设计,不过对于复杂的页面还需要进一步学习。

1. css

对于css的学习,我推荐分三块:“基础概念”,“css2.1规范”,“css3规范”。必看 精通CSS(第2版) (豆瓣),看完这本书你应该对:盒子模型,流动,block,inline,层叠,样式优先级,等概念非常了解了。这本确实有些年头了,但基础概念部分讲述非常清晰,可以称之为经典。ie6,7相关的内容可以不看。css3的部分可以参考:CSS3实用指南 (豆瓣)。这本书同样有些老,只是最新出版的书中没发现有特别好的。

关于浏览器兼容性。webkit内核已成为市场主流,ie6、7已成为历史,ie8、9的市场份额在进一步缩小,总之兼容IE已不在是前端工程师面试需要考察的点。

2. javascript

上面提到内容还不足以让你胜任js编程。在有了基础之后,进一步学习内容包括:

2.1. 简单框架。推荐先学 zepto,简单易用,在w3school简单学习js后,直接上手 zepto 即可完成一些简单的项目。zepto 源码简单清晰,也适合新手阅读。补充: 可以使用 codecademy 学习 javascript,zepto,用户体验真的很好(感谢 TonyOuyang )。学习zepto只是为了快速上手开发项目,获得成就感。同时还是要关注JS原生编程的能力,尤其随着低端浏览器份额的下降,很多 zepto API 已经可以被原生浏览器api替代。以天猫消费者端 h5页面为例,主要就是靠 原生JS + 少量 zepto api 的方式开发完成,配合pwa等浏览器最新api就可以开发出极致的用户体验。

2.2. 复杂框架。是指 react、vue、angular 等不直接操作dom的框架。这类框架建议js基础打扎实后再学习。复杂框架是用来解决复杂问题的。对于电商无线端导购页面来说原生JS足以。对于类似商家管理系统这类交互复杂,开发量大的系统,才适合用这类框架。对于这些框架核心在于理解理念,不要只停留在会用的层面。

2.3. javascript 语言范式 。这个名字可能并不恰当,只是我找不到可以描述“面向对象”,“函数式”这个两个概念的概念。javascript不完全是一个面向对象的语言,它的很多设计理念都有函数编程语言的影子,甚至说如果你不用面向对象,完全可以把它理解成一门函数式编程语言。javascript的很多语言特性,都是因为他具有函数式语言的特点才存在的。这部分推荐先学习面向对象的基本理论,对封装,继承,多态等概念要理解,维基百科,百度百科会是你的帮手,另外推荐《object oriented javascript》,应该有中文版。对与函数式编程可以参考这篇文章:JavaScript 中的函数式编程实践

2.4. javascript 语言内部机制。必须弄清如下概念:js中变量的作用域,变量传递方式,函数的定义环境与执行环境,闭包,函数的四种调用方式(一般函数,对象的方法,apply,call),以及四种调用方式下,‘this’指向的是谁。这部分内容你会在《javascript语言精粹》中详细了解。

2.5. dom编程,这个web前端工程师的核心技能之一。必读《dom编程艺术》,另外《高性能javascript》这本书中关于dom编程的部分讲的也很好。

2.6. 网络编程,这部分相对简单,就这些关键字,自己搜索学习即可:fetch,websocket,jsonp,cors,formData。另外,Ajax已经被 Fetch Standard 取代,学习 fetch api 即可,如果遇到不靠谱面试官还在问 ajax 的事情,直接跟他讲你对fetch的理解即可。

2.7. es5, es6。现在开发js大部分基于es5的,ie8以下通过es5-shim。但利用一些工具,现在已经可以直接写es6代码了,尤其在reactjs,nodejs类型的项目中。对于从es5,es6每个阶段js发生了哪些变化都需要系统学习,学习顺序建议是 JavaScript基础 -> es5 -> es6,越靠前的越重要。一些参考链接:ECMAScript 5 compatibility tableECMAScript 6入门ES5 « 张鑫旭

3. html5

需要了解html都提供了哪些api,然后项目中用起来。这部分没有什么难理解的,关键在于能用html5解决业务问题,以及不支持html5的浏览器的降级方案。这部分体现了前端的一个思想:面向未来编程,尽早将新技术引入业务中来,而不是过分考虑兼容性问题,进而导致面向过去编程

四、中级(2019年4月20日重写)

初级阶段的目标是能写出可以运行页面。中级阶段的目标则是以更快的速度,写出体验更好的页面。

1. 高内聚、低耦合

如果说数据结构和算法是从初级到高级的第一道门槛,能否写出高内聚、低耦合的代码,则是第二道门槛。

这部分是《设计模式》课程的主要内容,在《敏捷软件开发-模式、原则与实战》这部分书中也有更好解读,这里只能简单说下我的理解:

高内聚和低耦合的核心是内聚什么?解耦什么?简单来说就是一个分类问题,展开来说分类的原则包括:变化的角度,未来可能变化和不太可能变化的代码需要解耦;功能的角度,不同职能的代码必须解耦。从变化的角度理解,对应的原则包括:开放—封闭原则(OCP)、Liskov替换原则(LSP)、依赖倒置原则(DIP)、接口隔离原则(ISP);从功能的角度理解对应的原则是:单一责任原则(SRP)。至于单例、工厂、模板、代理等等设计模式,只是这些原则之下的具体解决方案。

所以如果再有面试官去考察你的设计模式功底,要先去跟他讲你对模式之上的原则的理解。具体的模式,在不通语言范式下的用法可能不同,甚至压根没用。但模式背后的原则,却在哪都能用。

2. 极致的用户体验

在 webkit + v8 组合出现之后,浏览器的性能得到很大提升,以至于在多数场景下前端工程师都不会面临的什么性能问题。这其实是从初级到中级的一道隐形的门槛,很多工作多年,由于工作场景的限制,接触不到什么问题,自己也没主动学习,导致在性能优化维度一片空白。

遗憾的是业务在发展,为了更高的开发效率,前端工程和组件体系的复杂度也在提升。很多场景下,我们依然要面临性能优化的问题。《高性能javascript》依然是这个领域的经典,部分过时内容(第五章,字符串和数组相关操作,V8已经做优化;第九章,构建部分,现在基于webpack已经有很成熟的方案了;第十章工具不用看,直接去看chrome的devtool文档)自己忽略一下即可。

总结一下:对于前端页面极致的用户体验围绕这三方面:加载体验、渲染体验、操作体验。千万不可以只知道优化加载体验,5G时代即将来临,网络速度回得到进一步提升,但CPU处理速度,貌似还没看到突破性进展,未来的用户体验问题,会更加聚焦到渲染体验和操作体验。

3. 工程效率

前端项目同样面临软件生命周期的各个环节,首先是代码管理,你必须学会使用git。其次是代码的构建,如今前端代码构建已经不是简单的压缩一下了,需要进行依赖管理、模块合并、各种编译,必须要学会使用webpack、rollup等前端构建工具,以及前端模块管理的方式,amd,cmd,es6 module 等等。

五、高级

从初级、到中级是可以根据教程(比如本文)或者参加培训而快速达到的。但进入高级只能靠自己,就算你找到一个“高级前端研修班”,学到了高级前端的技巧,也学不到灵魂。这里只提供一个前端知识结构,仅供进一步学习的


正走在从初级到中高级路上的大三或者研二的同学,如果想来阿里实习,可以扫下面二维码。

已经迈入高级阶段的前端同路人,如果想来阿里工作,可以邮件联系我。

原创文章,作者:27149,如若转载,请注明出处:http://wpbbw.com/4469.html

发表评论

登录后才能评论