第 一部分 函數式思想
第 1章 走近函數式 3
1.1 函數式編程有用嗎? 4
1.2 什麼是函數式編程? 5
1.2.1 函數式編程是聲明式
編程 7
1.2.2 副作用帶來的問題和
純函數 8
1.2.3 引用透明和可置換性 12
1.2.4 存儲不可變數據 13
1.3 函數式編程的優點 14
1.3.1 鼓勵復雜任務的分解 15
1.3.2 使用流式鏈來處理數據 16
1.3.3 復雜異步應用中的響應 18
1.4 總結 19
第 2章 高階JavaScript 21
2.1 為什麼要使用
JavaScript? 22
2.2 函數式與麵嚮對象的程序設計 22
2.2.1 管理JavaScript對象的
狀態 28
2.2.2 將對象視為數值 29
2.2.3 深凍結可變部分 31
2.2.4 使用Lenses定位並修改對象圖 33
2.3 函數 34
2.3.1 一等函數 35
2.3.2 高階函數 36
2.3.3 函數調用的類型 38
2.3.4 函數方法 39
2.4 閉包和作用域 40
2.4.1 全局作用域 42
2.4.2 函數作用域 43
2.4.3 僞塊作用域 44
2.4.4 閉包的實際應用 45
2.5 總結 48
第二部分 函數式基礎
第3章 輕數據結構,重操作 51
3.1 理解程序的控製流 52
3.2 鏈接方法 53
3.3 函數鏈 54
3.3.1 瞭解 lambda 錶達式 54
3.3.2 用_.map做數據變換 56
3.3.3 用_.reduce 收集結果 57
3.3.4 用_.filter 刪除不需要的
元素 61
3.4 代碼推理 62
3.4.1 聲明式惰性計算函數鏈 63
3.4.2 類SQL的數據:函數即
數據 66
3.5 學會遞歸地思考 68
3.5.1 什麼是遞歸? 68
3.5.2 學會遞歸地思考 68
3.5.3 遞歸定義的數據結構 70
3.6 總結 73
第4章 模塊化且可重用的
代碼 75
4.1 方法鏈與函數管道的
比較 76
4.1.1 方法鏈接 77
4.1.2 函數的管道化 78
4.2 管道函數的兼容條件 78
4.2.1 函數的類型兼容條件 78
4.2.2 函數與元數:元組的
應用 79
4.3 柯裏化的函數求值 82
4.3.1 仿真函數工廠 85
4.3.2 創建可重用的函數模闆 86
4.4 部分應用和函數綁定 87
4.4.1 核心語言擴展 89
4.4.2 延遲函數綁定 89
4.5 組閤函數管道 90
4.5.1 HTML部件的組閤 91
4.5.2 函數組閤:描述與求值
分離 92
4.5.3 函數式庫的組閤 95
4.5.4 應對純的代碼和不純的
代碼 96
4.5.5 point-free編程 98
4.6 使用函數組閤子來管理
程序的控製流 99
4.6.1 identity(I-combinator) 99
4.6.2 tap(K-組閤子) 99
4.6.3 alt(OR-組閤子) 100
4.6.4 seq(S-組閤子) 101
4.6.5 fork(join)組閤子 101
4.7 總結 102
第5章 針對復雜應用的設計
模式 103
5.1 命令式錯誤處理的
不足 104
5.1.1 用try-catch處理錯誤 104
5.1.2 函數式程序不應拋齣
異常 105
5.1.3 空值(null)檢查問題 106
5.2 一種更好的解決方案
——Functor 106
5.2.1 包裹不安全的值 107
5.2.2 Functor定義 108
5.3 使用Monad函數式地處理錯誤 111
5.3.1 Monad:從控製流到
數據流 111
5.3.2 使用Maybe Monad和Either Monad來處理異常 115
5.3.3 使用IO Monad與外部資源交互 123
5.4 Monadic鏈式調用及
組閤 126
5.5 總結 131
第三部分 函數式技能提升
第6章 堅不可摧的代碼 135
6.1 函數式編程對單元測試的影響 136
6.2 測試命令式代碼的
睏難 137
6.2.1 難以識彆和分解任務 137
6.2.2 對共享資源的依賴會導緻結果不一緻 138
6.2.3 按預定義順序執行 139
6.3 測試函數式代碼 140
6.3.1 把函數當作黑盒子 140
6.3.2 專注於業務邏輯,而不是控製流 141
6.3.3 使用Monadic式從不純的代碼中分離齣純函數 142
6.3.4 mock外部依賴 144
6.4 通過屬性測試製定規格
說明 146
6.5 通過代碼覆蓋率衡量有
效性 152
6.5.1 衡量函數式代碼測試的
有效性 152
6.5.2 衡量函數式代碼的
復雜性 155
6.6 總結 158
第7章 函數式優化 159
7.1 函數執行機製 160
7.1.1 柯裏化與函數上下文
堆棧 161
7.1.2 遞歸的弱點 164
7.2 使用惰性求值推遲
執行 165
7.2.1 使用函數式組閤子避免重復計算 167
7.2.2 利用shortcut fusion 167
7.3 實現需要時調用的
策略 168
7.3.1 理解記憶化 169
7.3.2 記憶化計算密集型
函數 169
7.3.3 有效利用柯裏化與
記憶化 172
7.3.4 通過分解來實現更大程度
的記憶化 173
7.3.5 記憶化遞歸調用 173
7.4 遞歸和尾遞歸優化 175
7.5 總結 178
第8章 管理異步事件以及
數據 181
8.1 異步代碼的挑戰 182
8.1.1 在函數之間創建時間依賴
關係 182
8.1.2 陷入迴調金字塔 183
8.1.3 使用持續傳遞式樣 186
8.2 一等公民Promise 188
8.2.1 鏈接將來的方法 190
8.2.2 組閤同步和異步行為 195
8.3 生成惰性數據 197
8.3.1 生成器與遞歸 199
8.3.2 迭代器協議 200
8.4 使用RxJS進行函數式和響應式編程 202
8.4.1 數據作為Observable
序列 202
8.4.2 函數式編程與響應式
編程 203
8.4.3 RxJS和Promise 205
8.5 總結 206
附錄 本書中使用的
JavaScript庫 207
函數式JavaScript庫 207
使用的其他庫 208
· · · · · · (
收起)
評分
☆☆☆☆☆
還是不好讀,不過比那本《JavaScript 函數式編程》要好一點,引入瞭兩個庫來講,感覺對初學函數式編程的人來說不太友好
評分
☆☆☆☆☆
還是不好讀,不過比那本《JavaScript 函數式編程》要好一點,引入瞭兩個庫來講,感覺對初學函數式編程的人來說不太友好
評分
☆☆☆☆☆
程序員路上的必讀書,哪怕你看不完,也學到瞭。書跟薄,讀起來可是真費勁。前三分之一還行,看得津津有味。後麵就算瞭,緣分還沒到。
評分
☆☆☆☆☆
不錯的js函數式相關的書,相關概念都有涉及。
評分
☆☆☆☆☆
Monad直接講濛圈瞭啊……完全不知所雲,我去瞅瞅Haskell好瞭。
評分
☆☆☆☆☆
js函数式编程指南 - 关于`_(users)`和`_.chain(users)`的区别[参考](https://blog.csdn.net/Soaring_Tiger/article/details/48136871) - 简单来说,显式链则用`_.chain`的方式实现延迟计算 - 方法链接与函数管道的比较 - 方法链接与方法所属的对象紧紧地耦合在一起,限制了使用...
評分
☆☆☆☆☆
js函数式编程指南 - 关于`_(users)`和`_.chain(users)`的区别[参考](https://blog.csdn.net/Soaring_Tiger/article/details/48136871) - 简单来说,显式链则用`_.chain`的方式实现延迟计算 - 方法链接与函数管道的比较 - 方法链接与方法所属的对象紧紧地耦合在一起,限制了使用...
評分
☆☆☆☆☆
js函数式编程指南 - 关于`_(users)`和`_.chain(users)`的区别[参考](https://blog.csdn.net/Soaring_Tiger/article/details/48136871) - 简单来说,显式链则用`_.chain`的方式实现延迟计算 - 方法链接与函数管道的比较 - 方法链接与方法所属的对象紧紧地耦合在一起,限制了使用...
評分
☆☆☆☆☆
js函数式编程指南 - 关于`_(users)`和`_.chain(users)`的区别[参考](https://blog.csdn.net/Soaring_Tiger/article/details/48136871) - 简单来说,显式链则用`_.chain`的方式实现延迟计算 - 方法链接与函数管道的比较 - 方法链接与方法所属的对象紧紧地耦合在一起,限制了使用...
評分
☆☆☆☆☆
js函数式编程指南 - 关于`_(users)`和`_.chain(users)`的区别[参考](https://blog.csdn.net/Soaring_Tiger/article/details/48136871) - 简单来说,显式链则用`_.chain`的方式实现延迟计算 - 方法链接与函数管道的比较 - 方法链接与方法所属的对象紧紧地耦合在一起,限制了使用...