概念
高阶函数:英文叫Higher-order function。Javascript 的函数其实都指向某个变量。既然变量可以指向函数的话,那么函数的参数也就能接收变量,那么一个函数就可以接受另一个函数作为参数,这就称之为高阶函数!
1.1 一个简单的高阶函数代码块!
function add(x, y, f) {
return f(x) + f(y);
}
//当调用add(-5, 6, Math.abs)时,参数x,y和f分别接收-5,6和函数Math.abs,根据函数定义,可以推导计算过程为:
//x = -5;
//y = 6;
//f = Math.abs;
//f(x) + f(y) ==> Math.abs(-5) + Math.abs(6) ==> 11;
//return 11;
//用代码验证一下:
add(-5, 6, Math.abs); // 11
简单介绍三个高阶函数也是开发中较为常见的!
map / reduce 、由于map方法定义在Javascript的Array中,我们调用的Array的map( ) 方法,传入我们自己的函数就得到一个新的Array作为一个结果:
(1)、map( )
function pow(x) {
return x * x;
}
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
arr.map(pow); // [1, 4, 9, 16, 25, 36, 49, 64, 81]
//map()传入的参数是pow,即函数对象本身。
//不需要map(),写一个循环,也可以计算出结果:
var f = function (x) {
return x * x;
};
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
var result = [];
for (var i=0; i result.push(f(arr[i]));
}
//的确可以,但是,从上面的循环代码,我们无法一眼看明白“把f(x)作用在Array的每一个元素并把结果生成一个新的Array”。
(2)、reduce
再看reduce的用法。Array的reduce()把一个函数作用在这个Array的[x1, x2, x3...]上,这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做累积计算,其效果就是:
var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {
return x + y;
}); // 25
们无法一眼看明白“把f(x)作用在Array的每一个元素并把结果生成一个新的Array”。
(3)、filter
filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。和map()类似,Array的filter()也接收一个函数。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。
//例如,在一个Array中,删掉偶数,只保留奇数,可以这么写:
var arr = [1, 2, 4, 5, 6, 9, 10, 15];
var r = arr.filter(function (x) {
return x % 2 !== 0;
});
r; // [1, 5, 9, 15] //得到过滤出的奇数值 很多业务场景都很好用 根据个人需求而定!
//把一个Array中的空字符串删掉,可以这么写:
var arr = ['A', '', 'B', null, undefined, 'C', ' '];
var r = arr.filter(function (s) {
return s && s.trim(); // 注意:IE9以下的版本没有trim()方法这只是个demo!
});
arr; // ['A', 'B', 'C']
filter在回到这里我们讲细一点
var arr = ['A', 'B', 'C'];
var r = arr.filter(function (element, index, self) {
console.log(element); // 依次打印'A', 'B', 'C'
console.log(index); // 依次打印0, 1, 2
console.log(self); // self就是变量arr
return true;
});
//利用filter,可以巧妙地去除Array的重复元素:
'use strict';
var r,
arr = ['apple', 'strawberry', 'banana', 'pear', 'apple', 'orange', 'orange', 'strawberry'];
r = arr.filter(function (element, index, self) {
return self.indexOf(element) === index;
});
alert(r.toString());
//去除重复元素依靠的是indexOf总是返回第一个元素的位置,后续的重复元素位置与indexOf返回的位置不相等,因此被filter滤掉了。
强调:filter去重上面这个当然不是最好的方法,只是告诉大家让你回顾一下围绕着filter去做一个简单的demo!