WEB 前端学习指南(下)

与文章的 上篇 相隔近 6 个月的时间,我才开始整理下篇。这 6 个月来我一直在不间歇地做运营活动的 H5 页面,写了很多重复的代码,做了很多简单的开发。因此,我还谈不上对 16 年的前端技术栈有多么深刻而有意义的解读。在这篇文章里,我没法给出富有创新的代码,我只能罗列出我学习和工作轨迹里所用到的工具与资源。

这篇文章的是写给进击的前端学习者,中级的前端开发(这并不意味这篇文章的内容不适合初学者,只是很多内容可能难以顾及初学者触及的深度)。那么我依然从三驾马车开始谈吧!

三驾马车:HTML5 + CSS3 + JavaScript

HMTL5 是 HTML 标准的最新演进版本。它是一个新的 HTML 语言版本包含了新的元素,属性和行为,同时包含了一系列可以被用来让 Web 站点和应用更加多样化,功能更强大的技术。从对 Web 开发人员有用这点触发,和基于它们的各自功能,可以将 HTML5 技术的资源归类成若干组:

  • 语义:能够更恰当的描述网页的内容
  • 连通性:能够和服务器使用创新的新技术方法进行通信
  • 离线 & 存储:能够让网页在客户端本地存储以及更高效地离线运行
  • 多媒体:使 video 和 audio 成为了 Web 中的一等公民
  • 2D/2D 绘图 & 效果,矢量图:提供更加丰富的呈现选择
  • 性能 & 集成:提供了非常显著的性能游湖和更有效的计算机硬件使用
  • 设备访问 Device Access:能够处理各种输入和输出设备

不可否认,这段解释我摘抄自 MDN。同时还有这个网页更详细的提供了 Web 技术示例,MDN 是 Mozilla 维护的技术文档。谷歌也同样提供了 Web 开发的指南,而且 google 提供的是具体的开发更优秀 Web 网页的方法和理论。
![](http://static.ohf2e.com/20170102/Google Web.PNG)

我记得在上篇我推荐的 HTML5 参考还是 w3cschool,但现在,我认为它完全过时了,并且毫无创意。它不像 MDN 那样提供完善的技术文档和参考资源,也不会像 google 告诉你如何做出更好的 Web 网页。使用 w3cschool 也许能让你做出一两道小菜,但是使用却不能让你做出满汉全席。

CSS3 ,在入门后我更关注的是如何使用 less 或 sass 。这样做的目的主要是解决两个问题:

  1. 避免类命名重复
  2. 实现代码的复用

但是,我想这里除了添加两个官网地址,还可以提到 CSS Modules。这是一篇详细 CSS Modules 的文章 ,它同样是为了解决上面的两个问题。

与此同时,我推荐一本关于 CSS3 的书籍——《css screts》。这本书给出了很多有意思的 CSS 技巧,比如:实现条纹背景,实现各种形状的 DIV 等等,我在上篇文章中有推荐过,但那时没有给出电子书的下载,上面的链接里是中文版的电子书。

当然,CSS3 里还有更有意思的新的布局方式——flexbox,我依稀记得年初刚接触这个概念的时候,在 Can I Use 上看到它兼容性还只到 70% 哦,但现在已经到 97%。

它完全可以取代我们以往使用 position,float 实现的各种布局,而且代码更优雅高效。可惜我还没有找到一本书完整的介绍 flexbox,这里推荐一系列 文章,里面虽然介绍了使用和实践案例,但我认为并不系统,只能勉强参考着用。

JavaScript 是脚本语言,从 ES6 开始变得更加强大,补充了非常多的新特性。因为我自己也还在学习中,就不讨论更多具体的语法了。但是,我想在经历过 16 年前端圈的快速变化和发展后,作为仍然在努力追赶的前端开发而言,掌握最基础的知识才能够以不变应万变。

同时,我认为大多数前端开发需要增强的技能是去掌握基于 JavaScript 的开发模式和算法。这里推荐三本书:
你不知道的 JavaScipt(上卷)
Javascript 设计模式与开发实践
数据结构与算法 Javascript 描述

理解产品、设计

很多时候,程序员被认为只需要埋头写代码,只要和电脑进行沟通。那么,作为前端也不例外应该更懂 0 和 1。但实际情况可能并非如此,前端要实现的是整个产品最接近用户那一侧,给用户最直观视觉呈现和功能呈现的代码(当然,这里的前端包括了开发 Web,App,和传统的桌面应用)。

前端首先要理解的就是产品经理给出的那份原型里面的功能逻辑,然后要对用户使用产品的场景和流程达到和产品经理一样的熟练,因为前端需要从原型开始实现产品,任何不合理的需求都会使开发变得异常困难。所以,我认为前端理解产品不仅仅是理解原型,而是对产品从前端代码侧的一种解构(这句话套用到后端和数据工程师,我以为同样受用。任何一个开发都应该理解自己开发的产品。),与产品经理从用户、运营和商业等多维角度解构,重构产品是一种补充的关系。

而 “理解设计” 就是为了按照设计 1 像素还原(有些设计稿可能无法完美实现,这就是要在定稿之前避免的)。我稍微想了下这几个问题:

  1. 理解设计的哪些部分?配色方案,整体布局,文案。
  2. 如何理解设计里的变化?自适应设计、响应式设计都是变化的设计。要在变化的屏幕设备里实现设计稿,那么前端就必须理解设计里变化的部分。
  3. 如何理解设计里的动态?这个指的就是 “交互” 嘛,我强行归纳到设计里了。

好吧,这个命题对我而言稍微有点强人所难,其实我也正在努力学习这些,这里就只能放一些我正在关注的网站和博客了:
美啊网
UIGREAT
图月志

前端性能和安全

前端的性能和安全是两个大命题,这里只能提及一二。一是我自己也要注意这方面知识和经验的积累,二是希望同样学习的前端伙伴们能够注意到这些。

前端的性能无疑是在开发过程中就要时刻注意和留心,但是性能的优化也是随着产品的复杂度才会变的重要。所以,一开始能够避开那些影响性能的地方应该就可以了。这里列出几篇文章,即提及了如何分析网页性能也给出了性能优化的方案:
那些年我们用过的显示性能指标
无线性能优化:Composite
web 性能优化之:no-cache 与 must-revalidate 深入探究
Javascript 高性能动画与页面渲染
HTTP 权威指南
Web 性能权威指南
图解 HTTP

前端的安全比起性能更是要时刻注意的。然而,因为我一直没有在实际开发中深入的接触如何使前端更安全,最多就是避免常见的 xss 攻击,过滤用户输入信息等,但这一部分却是我认为极为重要的,保证网站的安全是对企业和用户必须承担的责任。
这里我暂时只能提供下面这本电子书:
Web 前端黑客技术揭秘

前端流行框架

React 还是 Vue?

坦白说,就目前而言,我并没有使用过 React 或 Vue 框架完成过项目。实际上,这两也不能称为框架,React 自己都说过它只是 MVC 中的 view。真正称的上前端框架的是 Augular、backbone 等。但是无论如何还是要选择一个,因为前端入门都快要求要懂 React 或 Vue,Augular 了。

从学习曲线上看,Vue 会比很多框架都要容易一些。首先,它的主要开发是尤雨溪(微博 ID:尤小右),所以中文文档完善(当然很多其他语言的文档也都有);其次,Vue 比起 React,Augular 更容易理解。所以,可以先从 Vue 入门学习实践一些项目。

但最好也学一下 React。
……
果然,书到用时方恨少。

JavaScript 函数式编程

暂时不会,以后再说。但是,听说很火的概念。有空可以了解下,因为 React 底层好像用了大量的函数式编程的思想。

Linux 和数据库

我在上篇提及了 BAE,SAE 这类 sass 可以快速部署网站应用,但实际上这样的局限很大, 并不利于前端全面认识服务器和后端语言的面貌。所以,当学有余力,不妨自己在 linux 上搭建真实的服务器环境。
linux 虚拟机镜像下载
其实在虚拟机中搭建服务器环境或者购买 阿里云,腾讯云主机服务都可以,关键是自己动手实践能够对服务器环境有所认识。

数据库 是数据存储的地方,很多时候前端要理解后端接口,要根据数据库表的设计才能够理解。因此,我也自己尝试使用 mysql 和 MongoDB 写过小网站。但这部分我也研究不深,仅仅是到了通过文档能够理解数据库的读写改查。下面提供一本 MongogDB 的电子书,而 mysql 的资料目前实在寥若寒星。
MongoDB 实战

其他

最后再补充一些关于编码规范、代码测试、构建工具、协同工作、文档编写的内容。因为这部分需要懂得但不是前端的核心竞争力量(我自己的看法而已,我认为前端的核心竞争力是开篇头三节内容)

代码测试

因为上篇有提及编码规范,也基本没有需要补充的,故不再单列一小节来讲了。关于代码测试,这部分我也使用不多,但是我觉得当开发复杂度高到如果 native app 的时候,代码能够自测肯定能起到事半功倍的效果。但是,目前前端圈对代码测试的要求似乎并不高。这里我只提供一些文章参考:
(译) 学习如何构建自动化、跨浏览器的 JavaScript 单元测试
前端可视化的测试实践
【持续集成你的项目】为你的项目创建自动化测试和代码覆盖率测试

构建工具

目前 grunt 应该是会被淘汰的了,至于 gulp、webpack 或者 rollup 谁会成为前端构建工具的老大还不好说。目前我使用了 gulp 重新整理了公司项目的构建流程,具体实现可以参考 这篇文章

其实,能够深入理解某个构建工具并独立编写过针对具体项目的工具集以后,就可以驾驭大多数构建工具了。

协同工作

这部分我想将的是对版本管理和沟通交流的内容。我所接触到使用的版本管理工具是 git 和 svn,我想这部分只要多使用就会熟悉的,当然也要一定的理解,这里推荐一本 git 的书籍:
Git 权威指南

记住要和设计,后端保持愉快的沟通交流。不要再认为前端只要写好代码、做个死宅就行了,前端简直如果桥梁一般,连接了产品各个层面的工作人员。

文档编写

最后的最后强调一遍,程序员要会写文档,前端程序员要会写好看又好用的文档。至于具体怎么写,用 markdown 就可以了。

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

推荐阅读更多精彩内容