开篇词 (1讲)

开篇词 | 如何解决语言问题?

从零开始:JavaScript语言是如何构建起来的 (7讲)

01 | delete 0:JavaScript中到底有什么是可以销毁的
02 | var x = y = 100:声明语句与语法改变了JavaScript语言核心性质
03 | a.x = a = {n:2}:一道被无数人无数次地解释过的经典面试题
04 | export default function() {}:你无法导出一个匿名函数表达式
05 | for (let x of [1,2,3]) …:for循环并不比使用函数递归节省开销
加餐 | 捡豆吃豆的学问(上):这门课讲的是什么?

从表达式到执行引擎:JavaScript是如何运行的 (7讲)

06 | x: break x; 搞懂如何在循环外使用break,方知语句执行真解
07 | ${1}:详解JavaScript中特殊的可执行结构
08 | x => x:函数式语言的核心抽象:函数与表达式的同一性
09 | (…x):不是表达式、语句、函数,但它却能执行
10 | x = yield x:迭代过程的“函数式化”
11 | throw 1;:它在“最简单语法榜”上排名第三

从原型到类:JavaScript是如何一步步走向应用编程语言的 (6讲)

12 | 1 in 1..constructor:这行代码的结果,既可能是true,也可能是false
13 | new X:从构造器到类,为你揭密对象构造的全程
14 | super.xxx():虽然直到ES10还是个半吊子实现,却也值得一讲
15 | return Object.create(new.target.prototype):做框架设计的基本功:写一个根类
16 | [a, b] = {a, b}:让你从一行代码看到对象的本质
17 | Object.setPrototypeOf(x, null):连Brendan Eich都认错,但null值还活着

从粗通到精通的进阶之路:唯一不变的是变化本身 (5讲)

18 | a + b:动态类型是灾难之源还是最好的特性?(上)
19 | a + b:动态类型是灾难之源还是最好的特性?(下)
20 | (0, eval)("x = 100") :一行让严格模式形同虚设的破坏性设计(上)
21 | (0, eval)("x = 100") :一行让严格模式形同虚设的破坏性设计(下)
22 | new Function(‘x = 100’)();:函数的类化是对动态与静态系统的再次统一

结束语 (2讲)

结束语 | 愿你能做一个真正“懂”的程序员
结课测试 | 这些JavaScript知识,你真的掌握了吗?

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。