引用外界一等公民的定义:“在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)

好啦,这就是我今天要介绍的函数式编程第一曲,一等公民,要善于利用一等公民的权利,用更简单的方式做哦~



05-11 18:21