web前端 学习线路

1. 前言

  大约在几个月以前,让我看完了《webkit技术内幕》这本书的时候,忽然有了一个想法。想把整个web前端开发所须要的知识都之中在一个视图中,造成一个完整的web前端知识体系,目的是想要颠覆人们对于前端只有三大块(html、css、js)的认识——作web前端须要的比这三大块要多得多javascript

  拖了好几个月了,可是因为近期将要参加的某一个活动,我不得不这两天把这个东西整出来。说干就干。上午我就开始在办公室画草图,乱七八糟的在那儿理思路。css

  

下面请跟随我本博客的内容,来看看web前端开发除了htm、css和js以外,还有哪些东西须要你一步一步去掌握。在看内容以前,先看一下这个知识框架的预览图。html

  

2. 分类

  全部知识框架,那确定是一个结构型的展示,就是一棵树。web前端的知识点很是多,也很是散,须要好几层结构来组织这个体系,不然就会显得很乱。那么如何组织、把谁和谁放在一起?这是真正值得咱们去思考的,你也能够本身来思考一下这个问题。前端

  在我总结的这个知识框架中,首先第一层我划分为:理论知识,类库框架,编码开发,运行环境。以下图:java

  

  接下来给你们解释一下:node

  这个图要从下往上看,为什么?——由于下面是上面的基础;react

  • 首先,咱们须要必定的理论知识,不论是你听别人讲授、本身看书仍是网上淘资料,你都须要必定的理论知识,每一种程序开发,都避免不了。
  • 第二,有了这些理论知识咱们就能够编码了——不错——but,没有人能抵挡住第三方框架和类库的诱惑,例如jquery;
  • 第三,有了这些理论知识和协助咱们的类库框架,咱们就可真正的编码了。你们可能觉得编码开发不就是写代码吗,还有啥?——这里面道道多着呢;
  • 最后,开发程序的目的,最终是为了能高效、稳定的运行在相应的环境中,这其中又有哪些事情须要咱们去作?请期待;

3. 理论知识 包括“软知识”和“硬知识”

  “软知识”和“硬知识”你们可能以为词陌生,其实我一说你们就能明白。jquery

  

  • 所谓“软”的就是能在各个程序开发中都用到的,算是基本功、内功,例如数据结构、算法、设计模式、面向对象等等;
  • 所谓“硬”的就是能直接用于本程序开发的。用C语言你就得学C语言语法,此时学java没用。咱们web前端开发所须要的硬知识其实都包含在三个标准里面:http标准、W3C标准和ECMAScript标准

4. 聊一聊web前端开发中的“硬知识”

  “软知识”的内容很是多,也是咱们大学时代学习的重点(没学好是另回事儿,毕业再恶补)。咱们本次主要讨论的是web前端这一个方向,所以就点到为止,让你们知道这些知识也在知识体系中扮演重要角色。git

  刚才说道,硬知识有三个标准:http标准、W3C标准和ECMAScript标准,那我们就挨个聊聊这三个标准。github

4.1 http标准

  为何作web前端要了解http标准?——由于浏览器要从服务端获取网页,网页也可能将信息再提交给服务器,这其中都有http的链接。web系统既然和http连接有瓜葛,你就必须去了解它。

  

  个人意见是:你没必要去很是了解http的详细内容,可是你要了解web前端开发经常使用的一些http的知识——就是上图中我列出来的那些。固然,我知识列了一个纲,详细内容还得靠你本身去查阅(本文章讲的是知识框架,不会涉及任何知识点的详细内容)

  关于这方面的知识,建议去查阅《图解http》这本书,浅显易懂的讲述了这些内容,我曾经也看过。

4.2 W3C标准

  若是说你只知道web前端的一个标准,估计确定是W3C标准了(据我了解,貌似大部分人真的都只知道这一个标准)。它的内容很是多,看看www.w3.org/TR/这个页面。

  写到这里让我想起了一句话:2/8原则——20%的功能知足80%的需求。我以为这句话用到这里很是合适,咱们在平时开发过程当中根本用不到这么多东西。反而,你要把平时用的多的东西搞懂了。

  下图的这些知识,我想不用再过多解释了,这就是我文章开发说的“三大块”(html、css、js)。如今你要知道,它们只很少是W3C标准的一部分,而W3C标准也只是web前端开发知识体系中的一部分而已。

  (下图没有彻底展开,想看权展开的图,可下载本文一开始提供的附件)

  

  关于CSS的基础知识,毛遂自荐一下本身以前的一篇系列博客:《CSS知多少

4.3 ECMAScript  

  简称ES,写全称太麻烦了。

  有些人可能只知道javascript,而不知道ES——其实,js是在ES的基础上,为web浏览器作了一部分封装(增长了DOM操做、BOM操做等)。

  

  如上图中的这些概念,你们可能平时都在javascript中看到,其实他们是ES的内容。只不过javascript继承了ES的这些特性,而且javascript用的比较普遍,所以才会在js中讨论的多一些。

  仍是那个“2/8原则”。其实ES中的内容也很是多,并且更新很快,如今都到ES6了。可是我上图中列出来的这些都是最重要的概念。若是你不懂原型、闭包和做用域,那就说明你还不彻底了解ES,也就是不彻底会用javascript。

  在此毛遂自荐本身以前的一篇系列博客,你们能够去参考:《深刻理解javascript原型和闭包系列

5. 框架和类库

  前面已经描述完了web前端开发所须要的理论知识。如何实践呢?——不能蛮干——还得绕世界去看看,有哪些大牛已经为咱们作出了如此多的贡献。

  用下面的这些类库或者框架,能大大提升你的开发效率。

  

  • 首先,jquery必定是大部分web前端开发者不可或缺的工具。而我利用jquery不只仅停留在只使用它的API和插件上,我还会本身去写jquery插件,我还会去读jquery的源码、了解jquery的设计思路。若是你也能那样作,请相信我,你会收获到意想不到的效果。若是有一个问题:怎样才能最最透彻的理解javascript的事件系统?最佳答案之一:读几遍(一遍可能读不懂)jquery关于事件处理部分的源码!
  • bootstrap不用再过多解释了吧,从github上的排名也能看出道道来。甚至连咱们公司的UI设计师,都从bootstrap上截图做为素材。
  • fontAwesome是全世界最强大的图标系统。相比于css制做图标来讲,这个要好不少倍,不论是开发、效率仍是维护上。icomoon.io能让我自定义选择本身的图标文件。
  • requirejs和seajs这种模块定义系统,也必定是你系统中不可或缺的。我曾经看过一个教程,讲师就说:requirejs带来了既jquery以后的第二次前端技术变革。
  • 其余的,backbone、angular、react这些也慢慢的开始发挥了他们的价值,此处精力有限就再也不赘述了——可是,他们很重要——你至少要试着去了解它们。

6. 编码开发

  要问编码IDE哪家强,固然要属微软的visual studio!可是即使是微软的VS最新版本,它也代替不了下面要说的这套开发环境。

  

  若是你专门作web前端,就不要在用vs了,固然要选择sublime。写html语句还用手动一条一条写吗?你得须要zencoding的协助,不然效率太差了。

  另外,针对html、css、js的压缩、合并、语法检查,文件的清除、复制这些操做,你还要手动去作吗?——你须要grunt或者gulp的帮助。

  在此毛遂自荐本身的教程《用grunt搭建自动化web开发环境》,讲的比较详细,适合初学者学习。

  若是你的系统中有比较多的js代码或者文件,请选择一个合适的模块定义规范——CMD / AMD

  请用git来帮助你作文件版本管理,最简单的就是使用github。

  调试、测试,也都有专门的工具,都是须要学的……

  ——个人天哪……这些字写到如今写的个人手都酸了,别说要学习这些知识了——再也别说咱们web前端是“三大块”了!

7. 运行环境

  当系统真正到了运行环境中,当你以为终于完事儿的时候,其实还有好几个知识点须要你掌握。看下图:

  

  首先,你要知道web系统虽然大部分是在浏览器下运行,可是js可能会被运行在node环境。

  在浏览器环境下,最重要的两点是:web安全和性能优化。须要注意的纲要我都列出来了,若是想了解推荐两本书《白帽子将web安全》《高性能网站建设指南》