JavaScript 函数式编程 PDF 文档
全书共9章,分别介绍了 JavaScript 函数式编程、一等函数与 Applicative 编程、变量的作用域和闭包、高阶函数、由函数构建函数、递归、纯度和不变性以及更改政策、基于流的编程、无类编程。除此之外,附录中还介绍了更多函数式 JavaScript。
封面
书名
版权
前言
目录
第1章 JavaScript函数式编程简介
1.1 JavaScript案例
1.2 开始函数式编程
1.2.1 为什么函数式编程很重要
1.2.2 以函数为抽象单元
1.2.3 封装和隐藏
1.2.4 以函数为行为单位
1.2.5 数据抽象
1.2.6 函数式JavaScript初试
1.2.7 加速
1.3 Underscore示例
1.4 总结
第2章 一等函数与Applicative编程
2.1 函数是一等公民
2.2 Applicative编程
2.2.1 集合中心编程
2.2.2 Applicative编程的其他实例
2.2.3 定义几个Applicative函数
2.3 数据思考
2.4 总结
第3章 变量的作用域和闭包
3.1 全局作用域
3.2 词法作用域
3.3 动态作用域
3.4 函数作用域
3.5 闭包
3.5.1 模拟闭包
3.5.2 使用闭包
3.5.3 闭包的抽象
3.6 总结
第4章 高阶函数
4.1 以其他函数为参数的函数
4.1.1 关于传递函数的思考:max、finder和best
4.1.2 关于传递函数的更多思考:重复、反复和条件迭代
(iterateUntil)
4.2 返回其他函数的函数
4.2.1 高阶函数捕获参数
4.2.2 捕获变量的好处
4.2.3 防止不存在的函数:fnull
4.3 整合:对象校验器
4.4 总结
第5章 由函数构建函数
5.1 函数式组合的精华
5.2 柯里化(Currying)
5.2.1 向右柯里化,还是向左
5.2.2 自动柯里化参数
5.2.3 柯里化流利的API
5.2.4 JavaScript柯里化的缺点
5.3 部分应用
5.3.1 部分应用一个和两个已知的参数
5.3.2 部分应用任意数量的参数
5.3.3 局部应用实战:前置条件
5.4 通过组合端至端的拼接函数
5.5 总结
第6章 递归
6.1 自吸收(self-absorbed)函数(调用自己的函数)
6.1.1 用递归遍历图
6.1.2 深度优先自递归搜索
6.1.3 递归和组合函数:Conjoin和Disjoin
6.2 相互关联函数(函数调用其他会再调用回它的函数)
6.2.1 使用递归深克隆
6.2.2 遍历嵌套数组
6.3 太多递归了
6.3.1 生成器
6.3.2 蹦床原理以及回调
6.4 递归是一个底层操作
6.5 总结
第7章 纯度、不变性和更改政策
7.1 纯度
7.1.1 纯度和测试之间的关系
7.1.2 提取纯函数
7.1.3 测试不纯函数的属性
7.1.4 纯度与引用透明度的关系
7.1.5 纯度和幂等性
7.2 不变性
7.2.1 如果一棵树倒在树林里,有没有声音?
7.2.2 不变性与递归
7.2.3 冻结和克隆
7.2.4 在函数级别上观察不变性
7.2.5 观察对象的不变性
7.2.6 对象往往是一个低级别的操作
7.3 控制变化的政策
7.4 总结
第8章 基于流的编程
8.1 链接
8.1.1 惰性链
8.1.2 Promises
8.2 管道
8.3 数据流与控制流
8.3.1 找个一般的形状
8.3.2 函数可以简化创建action
8.4 总结
第9章 无类编程
9.1 数据导向
9.2 Mixins
9.2.1 修改核心原型
9.2.2 类层次结构
9.2.3 改变层级结构
9.2.4 用Mixin扁平化层级结构
9.2.5 通过Mixin扩展新的语义
9.2.6 通过Mixin混合出新的类型
9.2.7 方法是低级别操作
9.3 }).call(“Finis”);
附录A 更多函数式JavaScript
A.1 JavaScript的函数式库
A.1.1 函数式JavaScript
A.1.2 Underscore-contrib
A.1.3 RxJS
A.1.4 Bilby
A.1.5 allong.es
A.1.6 其他函数式库
A.2 能编译成JavaScript的函数式语言
A.2.1 ClojureScript
A.2.2 CoffeeScript
A.2.3 Roy
A.2.4 Elm
附录B 推荐书目
下载地址:https://www.wenjiangs.com/wp-content/uploads/staticcdn/pdf/586fd696-99ff2813.zip
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论