NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

你的前端知识框架,该如何搭建?

  • 2019-05-21
  • 本文字数:1856 字

    阅读完需:约 6 分钟

你的前端知识框架,该如何搭建?

你好,我是 winter。前端工程师是研发体系中的重要岗位之一。可是,与此相对的是,系统性的教学方案几乎找不到。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。


在上一篇专题留言中,我看到了很多前端工程师的困扰。



前端技术的更新如此迅速,在这样的大环境下,前端工程师保持自学能力就显得尤其重要了。因此,“学什么”“怎么学”就是我们要迫切解决的问题。


所以,我想带你梳理一套前端知识框架,帮你把知识点重新做个遍历,让你在学习的路上走的更轻松一些。这份知识框架,也是我在《重学前端》专栏里帮助大家重构前端架构的核心内容。

0 基础入门前端

对于 0 基础入门的同学,我建议你先去读几本经典的前端教材,打好起知识基础的地基。我们可以先从《JavaScript 高级程序设计》、《精通 CSS》看起。然后去阅读一些参考性质的网站,很推荐:MDN



《JavaScript 高级程序设计》


简介:《JavaScript 高级程序设计》被称为“程序员的红宝书”。几乎涵盖了 JavaScript 的大部分内容,有大量的例子,理解起来也并不太费解。



《精通 CSS》


简介:这本书将有用的 CSS 技术汇总在一起,还总结了 CSS 设计中的极具实践。CSS 看似简单,但真正精通 CSS 绝非易事。


如果你已经有 1 年以上的工作经验了,我们可以一起建立起前端的知识框架,再去把知识点做个遍历,这其中有原理和背景的部分,我去看知识的原理和背景就够了。如果没有的话,我们就去看整理和记忆这部分知识的方法,这样,即使你遇见无法一下子记住的知识,也可以很容易地查阅参考手册和标准来解决。

前端必备知识框架

我们先来讲讲什么叫做知识架构?我们可以把它理解为知识的“目录”或者索引,它能够帮助我们把零散的知识组织起来,也能够帮助我们发现一些知识上的盲区。


我们把前端知识在总体上分成基础部分和实践部分,基础部分包含了 JavaScript 语言、CSS 和 HTML 以及浏览器的实现原理和 API,这三个模块涵盖了一个前端工程师所需要掌握的全部知识,学完这三个部分,你再结合基本的编程能力,就可以应对基本的前端开发工作了。

JavaScript 知识架构图


在 JavaScript 的模块中,首先我们可以把语言按照文法、语义和运行时来拆分,这符合编程语言的一般规律:用一定的词法和语法,表达一定语义,从而操作运行时。


接下来,按照程序的一般规律,可以把运行时分为数据结构和算法部分——数据结构包含类型和实例(内置对象),算法是执行过程。


类型部分中,对象比其它所有类型加起来都复杂,所以我们会用较长的时间来学习对象,包括它的一些历史和设计思路。


执行过程应按照从大结构到小结构的角度来学习,从最顶层的事件循环和微任务,到函数、再到语句级的执行。


实例部分也很关键,但对 JavaScript 来说类似基础库,JavaScipt 的内置对象多达 150 以上,在MDN会有细致全面的讲解。


文法中的语法和语义基本是一一对应关系,在 JavaScript 标准中有一份语法定义表,建议随时拿出来看一看。

HTML 和 CSS 知识架构图


在 HTML 的部分,我们按照功能和语言来划分它的知识,HTML 的功能主要由标签来承担,所以首先要把标签做一些分类。


我们按照承担的不同功能,把标签分成下面几种。


  1. 文档元信息:通常是出现在 head 标签中的元素,包含了描述文档自身的一些信息;

  2. 语义相关:扩展了纯文本,表达文章结构、不同语言要素的标签;

  3. 链接:提供到文档内和文档外的链接;

  4. 替换型标签:引入声音、图片、视频等外部元素替换自身的一类标签;

  5. 表单:用于填写和提交信息的一类标签;

  6. 表格:表头、表尾、单元格等表格的结构。


除了标签之外,你还应该把 HTML 当作一门语言来了解下。但标记语言跟编程语言不太一样,比较基础的 HTML 的语法和几个重要的语言机制:实体、命名空间,你一定要掌握。


HTML 还有一个补充标准也很关键:ARIA,它是 HTML 的扩展,在可访问性领域,它有至关重要的作用。


CSS 部分,按照惯例,我们按照语言和功能划分。


  • 语言部分,@rule、选择器、单位是三个要关注的部分。

  • 功能部分,我们可以重点关注布局、绘制和交互类。


  • 在布局类的两个最常用的布局:正常流和弹性布局。

  • 绘制类,建议你分成图形相关的和文字相关的绘制。

浏览器的实现原理和 API


浏览器部分中浏览器的实现原理,是我们深入理解 API 的基础。


你可以从一般的浏览器设计出发,按照解析、构建 DOM 树、计算 CSS、渲染、合成和绘制的流程来学习浏览器的工作原理。


在 API 部分,可以从 W3C 零散的标准中挑选几个大块的 API 来详细讲解,主要有:事件、DOM、CSSOM 几个部分,他们分别覆盖了交互、语义和可见效果,这是我们工作中用到的主要内容。


内容选自极客时间《重学前端》专栏


2019-05-21 17:0313653

评论 1 条评论

发布
用户头像
理解对于极客邦来说赚钱很重要,但是不希望看到 InfoQ 上的文章都开始变成了内容预览。可以接受专门打广告,有用的话大家一定会付费。但不能接受想看更多请付费这类隐性广告。希望 InfoQ 永远火下去。
2019-05-22 05:09
回复
没有更多了
发现更多内容

工业制造业在数字化时代的三大发展方向

CECBC

六一儿童节,看我用ModelArts让8090梦回童年

华为云开发者联盟

AI 美食 童年 modelarts 六一

聚焦大企业创新与创投生态,2021 DEMO WORLD 世界创新峰会圆满成功!

创业邦

BoCloud博云微服务平台3.0正式发布:让微服务转型路径更清晰

BoCloud博云

微服务

全球案例 | 一家财富500强公司利用 Jira 和 Jira Align 将万人级团队的生产力提高了 30%

Atlassian

管理 DevOps 敏捷 Jira 协同办公

模块五总结

竹林七贤

mPaaS 月度小报 | 应用上线前都应该检查哪些指标?CodeHub#5回顾:小程序容器加持下的技术架构“提质增效”

蚂蚁集团移动开发平台 mPaaS

小程序 移动开发 mPaaS

Python3 Note 对象初始化

awen

Python 生命周期 对象初始化

webRTC探索音视频的录制的实现

云小梦

JavaScript WebRTC 浏览器API

环信MQTT消息云正式发布,覆盖4大核心场景

环信

mqtt

仅需1秒!快速查看海淀全区情况,一句话让“智慧屏”全搞定

百度大脑

智能

实现接口幂等性的四种方案!

李阿柯

面试 编程之路 幂等性

GitHub上收录400余篇任正非的讲话稿

不脱发的程序猿

GitHub 开源 程序人生 任正非讲话

个推CTO谈数据中台(上):从要求、方法论到应用实践

个推

大数据 数据中台 数字化转型 数据智能

新思科技推出Intelligent Orchestration解决方案 优化DevOps管道的速度和效率

InfoQ_434670063458

新思科技

智慧工厂VR拆解零件——3D虚实现实可视化系统

一只数据鲸鱼

数据可视化 工业互联网 vr 智慧工厂 零件拆解

净筹6亿美元:微盟正在加速拉开差距

ToB行业头条

SaaS 微盟

“图发展”与“保安全”:大数据今后怎么玩?

CECBC

计算机视觉常用图像数据集标记平台

不脱发的程序猿

人工智能 计算机视觉 图像处理 图像数据集标记平台

【LeetCode】包含min函数的栈Java题解

Albert

算法 LeetCode 6月日更

Python3 Note 函数注解

awen

Python Function 函数注解

百度智能云亮相CCBN2021,云智一体智媒产业智能化解决方案受关注

百度大脑

云智一体 CCBN

从VMWare安装到Nginx配置

wildpig

nginx vmware Centos 7

数字人民币有望为全球贸易结算开辟新视窗

CECBC

NUCLEO-L432KC实现GPIO控制(STM32L432KC)

不脱发的程序猿

嵌入式 stm32 单片机 NUCLEO-L432KC STM32L432KC

☕️【Java技术之旅】深入学习JIT编译器实现机制(原理篇)

洛神灬殇

Java 编译器 JIT 6月日更

Android studio 在外置硬盘运行项目报.lock 的错误

三爻

flutter android Mac Android Studio

Python3 Note __slots__

awen

Python slots

从零开始学习3D可视化之获取对象

ThingJS数字孪生引擎

物联网 可视化 大屏可视化 3D可视化 数字孪生

六一限定,致每一个追光者

白洞计划

《原则》(一)

Changing Lin

6月日更

你的前端知识框架,该如何搭建?_语言 & 开发_winter_InfoQ精选文章