高阶函数替换JavaScript中的循环

34次阅读

共计 1744 个字符,预计需要花费 5 分钟才能阅读完成。

JavaScript 新方法代替传统循环方法操作。本篇文章对比介绍实际场景方法运用。

为什么高阶函数替换循环?

使用高阶函数将使您的代码可以使你的代码可读性更强,易于理解,便于调试。

JavaScript 高阶函数替换循环

场景示例

一、遍历数组元素,返回一个修改后的新数组。

e.g. 将数组元素转换为大写

循环方式:

const animal = ['dog', 'cat', 'monkey', 'tiger'];
let upperCaseAnimal = [];
for(const item of animal) {upperCaseAnimal.push(item.toUpperCase());
}
// 输出
0: "DOG"
1: "CAT"
2: "MONKEY"
3: "TIGER"

不用循环

const animal = ['dog', 'cat', 'monkey', 'tiger'];
let upperCaseAnimal = animal.map(item => item.toUpperCase());

结果也是一样。

二、遍历数组元素,并执行某一方法。

循环:

const animal = ['dog', 'cat', 'monkey', 'tiger'];
function output(name) {console.log(name);
}
for (const item of animal) {output(item);
}

不用循环:

const animal = ['dog', 'cat', 'monkey', 'tiger'];
function output(name) {console.log(name);
}
animal.forEach(name=> output(name));

三、数组元素过滤。

e.g. 返回数组中的奇数。

循环:

const numbers = [1, 2, 3, 4, 5];
const odd = [];
for (const item of numbers) {if ( item % 2) {odd.push(item);
  }
}

不用循环:

const numbers = [1, 2, 3, 4, 5];
const odd = numbers.filter(item => item % 2);
// 输出结果
[1, 3, 5]

四、数组元素求和。

循环:

const numbers = [1, 2, 3, 4, 5];
let result = 0;
for (const item of numbers) {result  = item;}

不用循环:

const numbers = [1, 2, 3, 4, 5];
let result = numbers.reduce((acc, val) => acc + val, 0);
// 输出结果
15

五、检测数组中的元素是否满足指定条件。

循环:

const numbers = [1, 2, 3, 4, 5];
for (const item of numbers) {if (item === 3) {console.log('Y');
  }
}

不用循环:

const numbers = [1, 2, 3, 4, 5];
console.log(numbers.some(item => item === 3));

补充:

some() 方法用于检测数组中的元素是否满足指定条件(函数提供)。

some() 方法会依次执行数组的每个元素:

如果有一个元素满足条件,则表达式返回 true , 剩余的元素不会再执行检测。

如果没有满足条件的元素,则返回 false。

注意:some() 不会对空数组进行检测。

注意:some() 不会改变原始数组。

六、检查数组中每个元素是否均满足指定条件。

循环:

const numbers = [1, 2, 3, 4, 5];
for (const item of numbers) {if (item > 0) {console.log(item);
  }
}

不用循环:

const numbers = [1, 2, 3, 4, 5];
console.log(numbers.every(item => item > 0));

补充:

every() 方法用于检测数组所有元素是否都符合指定条件(通过函数提供)。

every() 方法使用指定函数检测数组中的所有元素:

如果数组中检测到有一个元素不满足,则整个表达式返回 false,且剩余的元素不会再进行检测。

如果所有元素都满足条件,则返回 true。

注意:every() 不会对空数组进行检测。

注意:every() 不会改变原始数组。

好了,就到这里,晚安!????

正文完
 0