引用外界一等公民的定义:“在JavaScript世界中函数却是一等公民,它不仅拥有一切传统函数的使用方式(声明和调用),而且可以做到像简单值一样赋值、传参、返回,这样的函数也称之为第一级函数(First-class Function)”。
那么,现在我要介绍的可是很厉害的哟~
(小试牛刀)
首先我们看一个栗子:
var getSum = function(number) { return 8 + number; }
var applySum = function(number) { return getSum(number); }
怎么样?是不是特别愚蠢,applySum只是执行并返回了跟getSum一样的值。在js中,函数是可被调用的(callable):
getSum(2); //10;
getSum //function(number){ return 8 + number; }
只要传的参数一样,applySum跟getSum就是在做一模一樣的事情,所以完全可以用一下代码来声明applySum:
var applySum = getSum;
(厨师进阶)
再来一道菜:
var getDish = function(cookDish) {
return sayHungry(function(index) {
return cookDish(index);
});
}
}
等价于:
var getDish = sayHungry;
来来,分析一波:
sayHungry(function(index) {
return cookDish(index);
});
等价与sayHungry(cookDish);
原来的getDish可变为:
var getDish = function(cookDish) {
return sayHungry(cookDish);
};
而,
function(cookDish) {
return sayHungry(cookDish);
}
等价于:
sayHungry;
所以,
getDish = sayHungry;
got it? (厨师反思)
为何钟爱一等公民function? 还是举栗子:
get('/api/apple', function(response)) {
return renderGet(response);
})
这种方式的弊端在于,假使我的get api,需要回调函数有两个参数,那么我必须得再加一个参数,如下:
get('/api/apple', function(response, error) {
return renderGet(response, error);
})
写成first class的function,要方便的多:
get('/api/apple', renderGet)
好啦,这就是我今天要介绍的函数式编程第一曲,一等公民,要善于利用一等公民的权利,用更简单的方式做哦~