53 lines
1.1 KiB
JavaScript
53 lines
1.1 KiB
JavaScript
|
## 高阶函数
|
|||
|
|
|||
|
### 高阶函数的概念
|
|||
|
|
|||
|
当 函数 A 接收函数 B 作为**参数**,或者把函数 C 作为**返回值**输出时,我们称 函数 A 为高阶函数。
|
|||
|
|
|||
|
通俗来说,高阶函数是 对其他函数进行操作 的函数。
|
|||
|
|
|||
|
|
|||
|
### 高阶函数举例1:把其他函数作为参数
|
|||
|
|
|||
|
```js
|
|||
|
function fn1(a, b, callback) {
|
|||
|
console.log(a + b);
|
|||
|
// 执行完上面的 console.log() 语句之后,再执行下面这个 callback 函数。也就是说,这个 callback 函数是最后执行的。
|
|||
|
callback && callback();
|
|||
|
}
|
|||
|
|
|||
|
fn1(10, 20, function () {
|
|||
|
console.log('我是最后执行的函数');
|
|||
|
});
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
|
|||
|
打印结果:
|
|||
|
|
|||
|
```
|
|||
|
30
|
|||
|
我是最后执行的函数
|
|||
|
```
|
|||
|
|
|||
|
|
|||
|
### 高阶函数举例2:把其他区函数作为返回值
|
|||
|
|
|||
|
|
|||
|
|
|||
|
```js
|
|||
|
function fn1() {
|
|||
|
let a = 20;
|
|||
|
|
|||
|
return function () {
|
|||
|
console.log(a);
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
const foo = fn1(); // 执行 fn1() 之后,会得到一个返回值。这个返回值是函数
|
|||
|
foo();
|
|||
|
```
|
|||
|
|
|||
|
|
|||
|
上面的代码,产生了闭包现象。关于闭包,详见下一篇文章《JavaScript基础/闭包.md》。
|