课程背景:
- 前端的主要编程语言为Javascript。
- Javascript做为一种融合了多种编程范式的语言,灵活性非常高。
- 前端开发人员需要根据场景在不同编程范式间字汝晞切换。
- 进一步需要制造领域特定语言抽象业务问题。
课程收益:
- 了解不同编程范式的起源和使用场景。
- 掌握Javascript在不同的编程范式特别是函数式编程范式的使用。
- 掌握创建领域特定语言的相关工具和模式。
高级语言:
C/C++
C:“中级语言”过程式语言代表
- 可对位,字节地址直接操作;
- 代码和数据分离倡导结构化编程
- 功能齐全:数据类型和控制逻辑多样化
- 可移植能力强
C++:面向对象语言代表
- C with Classes
- 继承
- 权限控制
- 虚函数
- 多态
Lisp:函数式语言代表
- 与机器无关
- 列表:代码即数据
- 闭包
Javascript
- 基于原型和头等函数的多范式语言
- 过程式
- 面向对象
- 函数式
- 响应式*
编程范式
分类:
- 命令式:面向过程;面向对象
- 声明式:函数式;响应式
过程式编程:自顶向下
结构化编程:
顺序结构;选择结构;循环结构
面向过程问题
- 数据与算法全联弱
- 不利于修改和扩充
- 不利于代码重用
面向对象编程
- 封装
- 继承
- 多态
- 依赖注入*
面向对象编程五大原则:
- 单一职责原则SSR
- 开放封闭原则OCP
- 里式替换原则LSP
- 依赖倒置原则DIP
- 接口分离原则ISP
面向对象问题:
面向对象编程语言的问题在于,它总是附带着所有它需要的隐含环境。你想要一个香蕉,但得到的却是一个大猩猩拿着香蕉,而且还有整个丛林。
————Joe Armstrong (Erlang创始人)
函数式编程
- 函数是“第一等公民”
- 纯函数/无副作用
- 高阶函数/闭包
函数式编程_Pure Function
- 优势
- 可缓存
- 可移植
- 可测试
- 可推理
- 可并行
函数式编程_Currying
函数式编程_Composition
- 可以当作容器的类型,类型支持对容器内元素进行操作
- 常见的functor:Array(lterable).map,Promise.then
函数式编程_Monad
- 可以去除嵌套容器的容器类型
- 常见monad:Array.flatMap Promise.then
函数式编程_Applicative
- 直接对两个容器直接操作
响应式编程
- 异步/离散的函数式编程
- 数据流
- 操作符
- 过滤
- 合并
- 转化
- 高阶
响应式编程
- 观察者模式
- 迭代器模式
- Promise/EventTarget超集*
响应式编程_操作符
- 响应式编程的“compose”
- 合并
- 过滤
- 转化
- 异常处理
响应式编程_Monad
- 去除嵌套的Observable
- 多播