41 lines
2.5 KiB
Markdown
41 lines
2.5 KiB
Markdown
|
---
|
|||
|
title: Higher Order Functions
|
|||
|
localeTitle: Функции более высокого порядка
|
|||
|
---
|
|||
|
## Функции более высокого порядка
|
|||
|
|
|||
|
Функция высшего порядка - это любая функция, которая возвращает функцию при выполнении, принимает функцию как один или несколько своих аргументов или и то, и другое. Если вы использовали какой-либо из методов `Array` например `map` или `filter` , или передали функцию обратного вызова в `$.get` jQuery, вы уже работали с функциями более `$.get` порядка.
|
|||
|
|
|||
|
Когда вы используете `Array.map` , вы предоставляете функцию как единственный аргумент, который применяется к каждому элементу, содержащемуся в массиве.
|
|||
|
|
|||
|
```javascript
|
|||
|
var arr = [ 1, 2, 3 ];
|
|||
|
|
|||
|
var arrDoubled = arr.map(function(num) {
|
|||
|
return num * 2;
|
|||
|
});
|
|||
|
|
|||
|
console.log(arrDoubled); // [ 2, 4, 6 ]
|
|||
|
```
|
|||
|
|
|||
|
Функции более высокого порядка также могут возвращать функцию. Например, вы можете сделать функцию `multiplyBy` которая принимает число и возвращает функцию, которая умножает другое число, которое вы предоставляете первым предоставленным номером. Вы можете использовать этот подход для создания функции `multiplyByTwo` для перехода к `Array.map` . Это даст вам тот же результат, который вы видели выше.
|
|||
|
|
|||
|
```javascript
|
|||
|
function multiplyBy(num1) {
|
|||
|
return function(num2) {
|
|||
|
return num1 * num2;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var multiplyByTwo = multiplyBy(2);
|
|||
|
|
|||
|
var arr = [ 1, 2, 3 ];
|
|||
|
|
|||
|
var arrDoubled = arr.map(multiplyByTwo);
|
|||
|
|
|||
|
console.log(arrDoubled); // [ 2, 4, 6 ]
|
|||
|
```
|
|||
|
|
|||
|
См. Руководство по [закрытию](https://guide.freecodecamp.org/javascript/closures) для получения дополнительной информации о том, как `multiplyByTwo` сохраняет ссылку на `num1` в приведенном выше примере.
|
|||
|
|
|||
|
[Дополнительная информация о Closures](https://eloquentjavascript.net/05_higher_order.html)
|