第1章 JavaScript函数式编程简介 1
1.1 JavaScript案例 1
1.2 开始函数式编程 4
1.2.1 为什么函数式编程很重要 4
1.2.2 以函数为抽象单元 7
1.2.3 封装和隐藏 9
1.2.4 以函数为行为单位 10
1.2.5 数据抽象 14
1.2.6 函数式JavaScript初试 17
1.2.7 加速 19
1.3 Underscore示例 22
1.4 总结 23
第2章 一等函数与Applicative编程 24
2.1 函数是一等公民 24
2.2 Applicative编程 30
2.2.1 集合中心编程 31
2.2.2 Applicative编程的其他实例 32
2.2.3 定义几个Applicative函数 35
2.3 数据思考 36
2.4 总结 43
第3章 变量的作用域和闭包 44
3.1 全局作用域 44
3.2 词法作用域 46
3.3 动态作用域 47
3.4 函数作用域 51
3.5 闭包 52
3.5.1 模拟闭包 53
3.5.2 使用闭包 57
3.5.3 闭包的抽象 59
3.6 总结 60
第4章 高阶函数 62
4.1 以其他函数为参数的函数 62
4.1.1 关于传递函数的思考:max、finder和best 63
4.1.2 关于传递函数的更多思考:重复、反复和条件迭代
(iterateUntil) 65
4.2 返回其他函数的函数 67
4.2.1 高阶函数捕获参数 69
4.2.2 捕获变量的好处 69
4.2.3 防止不存在的函数:fnull 72
4.3 整合:对象校验器 74
4.4 总结 77
第5章 由函数构建函数 78
5.1 函数式组合的精华 78
5.2 柯里化(Currying) 83
5.2.1 向右柯里化,还是向左 84
5.2.2 自动柯里化参数 85
5.2.3 柯里化流利的API 88
5.2.4 JavaScript柯里化的缺点 89
5.3 部分应用 89
5.3.1 部分应用一个和两个已知的参数 91
5.3.2 部分应用任意数量的参数 92
5.3.3 局部应用实战:前置条件 93
5.4 通过组合端至端的拼接函数 96
5.5 总结 98
第6章 递归 100
6.1 自吸收(self-absorbed)函数(调用自己的函数) 100
6.1.1 用递归遍历图 105
6.1.2 深度优先自递归搜索 106
6.1.3 递归和组合函数:Conjoin和Disjoin 108
6.2 相互关联函数(函数调用其他会再调用回它的函数) 110
6.2.1 使用递归深克隆 111
6.2.2 遍历嵌套数组 112
6.3 太多递归了 114
6.3.1 生成器 117
6.3.2 蹦床原理以及回调 120
6.4 递归是一个底层操作 121
6.5 总结 122
第7章 纯度、不变性和更改政策 123
7.1 纯度 123
7.1.1 纯度和测试之间的关系 124
7.1.2 提取纯函数 125
7.1.3 测试不纯函数的属性 126
7.1.4 纯度与引用透明度的关系 127
7.1.5 纯度和幂等性 129
7.2 不变性 130
7.2.1 如果一棵树倒在树林里,有没有声音? 132
7.2.2 不变性与递归 133
7.2.3 冻结和克隆 134
7.2.4 在函数级别上观察不变性 136
7.2.5 观察对象的不变性 137
7.2.6 对象往往是一个低级别的操作 140
7.3 控制变化的政策 141
7.4 总结 144
第8章 基于流的编程 145
8.1 链接 145
8.1.1 惰性链 148
8.1.2 Promises 152
8.2 管道 154
8.3 数据流与控制流 158
8.3.1 找个一般的形状 161
8.3.2 函数可以简化创建action 164
8.4 总结 166
第9章 无类编程 167
9.1 数据导向 167
9.2 Mixins 173
9.2.1 修改核心原型 175
9.2.2 类层次结构 176
9.2.3 改变层级结构 179
9.2.4 用Mixin扁平化层级结构 180
9.2.5 通过Mixin扩展新的语义 185
9.2.6 通过Mixin混合出新的类型 187
9.2.7 方法是低级别操作 188
9.3 }).call(“Finis”); 190
附录A 更多函数式JavaScript 191
A.1 JavaScript的函数式库 191
A.1.1 函数式JavaScript 191
A.1.2 Underscore-contrib 192
A.1.3 RxJS 192
A.1.4 Bilby 194
A.1.5 allong.es 195
A.1.6 其他函数式库 196
A.2 能编译成JavaScript的函数式语言 196
A.2.1 ClojureScript 196
A.2.2 CoffeeScript 197
A.2.3 Roy 198
A.2.4 Elm 198
javaScript函数式编程
时间: 2024-10-07 06:29:08
javaScript函数式编程的相关文章
JavaScript函数式编程(三)
JavaScript函数式编程(一) JavaScript函数式编程(二) 在第二篇文章里,我们介绍了 Maybe.Either.IO 等几种常见的 Functor,或许很多看完第二篇文章的人都会有疑惑: 『这些东西有什么卵用?』 事实上,如果只是为了学习编写函数式.副作用小的代码的话,看完第一篇文章就足够了.第二篇文章和这里的第三篇着重于的是一些函数式理论的实践,是的,这些很难(但并非不可能)应用到实际的生产中,因为很多轮子都已经造好了并且很好用了.比如现在在前端大规模使用的 Promise
20170917 前端开发周报:JavaScript函数式编程、作用域和闭包
1.用函数式编程对JavaScript进行断舍离 当从业20的JavaScript老司机学会函数式编程时,他扔掉了90%的特性,也不用面向对象了,最后发现了真爱啊!!! https://juejin.im/entry/59b86... 2.JavaScript作用域和闭包 作用域和闭包在JavaScript里非常重要.但是在我最初学习JavaScript的时候,却很难理解.这篇文章会用一些例子帮你理解它们.我们先从作用域开始.作用域 JavaScript的作用域限定了你可以访问哪些变量.有两种作
JavaScript函数式编程(1):基本思想
1 函数式编程简介 函数式编程是和传统命令式编程区分的一种编程思想,"在函数式编程语言中,函数是第一类的对象,也就是说,函数 不依赖于任何其他的对象而可以独立存在,而在面向对象的语言中,函数 ( 方法 ) 是依附于对象的,属于对象的一部分.这一点决定了函数在函数式语言中的一些特别的性质,比如作为传出 / 传入参数,作为一个普通的变量等.[1]" 函数式编程思想的源头可以追溯到 20 世纪 30 年代,数学家阿隆左 . 丘奇在进行一项关于问题的可计算性的研究,也就是后来的 lambda
javascript 函数式编程
编程范式 编程范式是一个由思考问题以及实现问题愿景的工具组成的框架.很多现代语言都是聚范式(或者说多重范式): 他们支持很多不同的编程范式,比如面向对象,元程序设计,泛函,面向过程,等等. 函数式编程范式 函数式编程就像一辆氢燃料驱动的汽车——先进的未来派,但是还没有被广泛推广.与命令式编程相反,他由一系列语句组成,这些语句用于更新执行时的全局状态.函数式编程将计算转化作表达式求值.这些表达式全由纯数学函数组成,这些数学函数都是一流的(可以被当做一般值来运用和处理),并且没有副作用. 函数式编程
在JavaScript函数式编程里使用Map和Reduce方法
所有人都谈论道workflows支持ECMAScript6里出现的令人吃惊的新特性,因此我们很容易忘掉ECMAScript5带给我们一些很棒的工具方法来支持在JavaScript里进行函数编程,这些工具方法我们现在可以使用了.在这些函数方法里主要的是基于JavaScript 数组对象的map()方法和reduce()方法. 如果你如今还没有使用map()和reduce()方法,那么现在是时候开始使用了.如今绝大部分的JavaScript开发平台都与生俱来的支持ECMAScript5.使用Map方
javascript函数式编程简单介绍
函数式编程在前端已经成为了一个热门的话题,近几年很多的应用程序代码库里大量使用着函数式编程思想.这里对JavaSctipt中的函数式编程做一个简单介绍. 什么是函数式编程 函数式编程是一种编程范式,主要是利用函数把运算过程封装起来,通过组合各种函数来计算结果.函数式编程意味着开发者可以在更短的时间内编写具有更少错误的代码. 函数式编程的简单例子 假设要把一个字符串转换成每个单词首字母大写,可以这样来实现: var string = 'i do like yanggb'; var result =
JavaScript函数式编程(0):函数基础 arguments、this、apply()、call()
1 函数参数 函数的实参和形参个数可以不等,之所以会这样,原因是 ECMAScript 中的参数在内部是用一个数组来表示的.函数接收到的始终都是这个数组,而不关心数组中包含哪些参数(如果有参数的话).如果实参个数大于形参个数,多余的实参不传递值,但是在arguments中可以访问:如果形参个数大于实参,没有传递值的实参将自动被赋予 undefined 值. 2 arguments和this 所有的函数调用都会传递两个隐式参数:arguments和this.实际上,在函数体内可以通过 argume
javaScript函数式编程-包含闭包、链式优化及柯里化
本文着重介绍个人理解的函数式编程. 函数式编程个人理解为:以函数为主要载体的编程方式. 好处: 语义更加清晰 可复用性高 可维护性好 作用域局限.副作用少 基本函数式编程: //实现数组中每个单词首字母大写 //一般写法 const arr = ['apple','orange','pear']; for(const i in arr) { const c = arr[i][0]; arr[i] = c.toUpperCase() + arr[i].slice(1); //slice()从已有的
javascript函数式编程一例分析
js像其他动态语言一样是可以写高阶函数的,所谓高阶函数是可以操作函数的函数.因为在js中函数是一个彻彻底底的对象,属于第一类公民,这提供了函数式编程的先决条件. 下面给出一个例子代码,出自一本js教程,功能是计算数组元素的平均值和标准差,先列出非函数式编程的一种写法: var data = [1,1,3,5,5]; var total = 0; for(var i = 0;i < data.length;i++) total += data[i]; var mean = tatal/data.l