随着对js的深入,有一种编程思想越发重要,那就是 函数式编程思想。
函数式编程思想就是 将复杂的函数转变成为简单的函数。通过嵌套的函数调用来实现这一过程
函数式编程通常有一下几个特点:
1. 函数是 “第一等公民”:函数如其他数据类型一样,可以赋值,可以作为参数和返回值
2.函数有明确的输入和输出:相当于高中数学中的映射,对于相同的输入,只会返回相同的输出
3.函数无副作用:不会对dom进行操作,不会修改全局变量
4.无外部影响:函数的运行不依赖外部的变量,只会受入参的影响。
函数式编程的的核心:
1.纯函数
相同的输入只会得到相同的输出,无副作用,无外部依赖
Array对象方法中的 slice 和 splice,slice是不改变原数组,而splice会修改原数组,所以不纯洁
2.函数柯里化
将一个多参数的函数转为单个参数的函数称为函数的柯里化,柯里化之后的函数称为柯里化函数。
var add=function(x,y){//普通函数 return x+y } add(1,2)//3
var add=function(x){//柯里化函数 return function(y){ return x+y } }
let add=x=>y=>x+y//es6的写法,是不是很简洁 add(1)(2)//3
柯里化函数相比于不同函数更加高效,简洁。
柯里化函数由于只有一个参数,在运行时会读取缓存,因而可以提高性能
3.函数组合
函数组合顾名思义就是把多个函数组合在一起
//两个函数的组合 var compose = function(f, g) { return function(x) { return f(g(x)); }; }; //或者 var compose = (f, g) => (x => f(g(x))); var add1 = x => x + 1; var mul5 = x => x * 5; compose(mul5, add1)(2); // =>15
4.Point Free
pointfree 模式指的是,永远不必说出你的数据。它的意思是说,函数无须提及将要操作的数据是什么样的。纯函数、函数柯里化以及函数
// 非 pointfree,因为提到了数据:word var snakeCase = function (word) { return word.toLowerCase().replace(/\s+/ig, '_'); }; // pointfree var snakeCase = compose(replace(/\s+/ig, '_'), toLowerCase);
组合协作起来非常有助于实现这种模式。