我这岁数的程序圆,学点东西不容易啊,不比你们小年轻啊!
所以,别浪费时间了,继续肝吧。
高阶函数-函数作为参数
优点:
- 更加灵活
- 调用函数时不需要考虑它内部是如何实现的,它把内部实现的细节给我们封装好了
- 函数名更具有实际意义
示例-1:
/**
* 模拟forEach
* 这是一个遍历函数,但是我们不确实最终的结果是直接打印,还是输出到页面上,所以我们传入一个匿名函数,去自行处理
*/
function forEach(arr, fn) {
for (var i in arr) {
fn(arr[i]);
}
}
let aaa = [1, 2, 3, 4, 5];
forEach(aaa, function (item) {
// 最终结果
console.log(item);
});
示例-2:
/**
* 模拟filter
* 这是一个过滤函数,但我们不确实过滤条件,这时我们可以传一个匿名函数,
* 过滤条件我们在调用filter函数的时候,通过传入的匿名函数去完成,filter函数直接返回执行结果
*/
function filter(arr, fn) {
let result = [];
for (var i in arr) {
if (fn(arr[i])) {
result.push(arr[i]);
}
}
return result;
}
let bbb = [4, 5, 6, 7, 8];
let r = filter(bbb, function (item) {
// 逻辑代码 - 取偶数
return item % 2 == 0;
});
console.log(r)
上边是两个很普通的小例子,在实际开发过程中,有很多类似的场景,所以把函数做为参数传入还是很有必要的
每天写写博客,果然就是超越自己。