.forEach() 和 .map() 都是 JavaScript 数组的迭代方法,用于对数组中的每个元素执行某个操作。它们之间的主要区别在于返回值和使用情况。
1. forEach() 方法:
.forEach() 方法用于遍历数组中的每个元素,并对每个元素执行指定的回调函数。该方法没有返回值,它仅用于执行副作用操作(如修改数组或输出结果)。
1.1 语法:
javascript
array.forEach(function(currentValue, index, array) {
// 执行操作
});
1.2 参数:
- currentValue:当前遍历的元素值。
- index(可选):当前遍历的元素索引。
- array(可选):正在被遍历的原始数组。
1.3 示例:
javascript
var numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(num) {
console.log(num * 2); // 输出每个元素的两倍
});
输出结果:
javascript
2
4
6
8
10
.forEach() 方法遍历数组中的每个元素,并对每个元素执行回调函数。在上述示例中,我们输出了每个元素的两倍。
2. map() 方法:
- .map() 方法用于遍历数组中的每个元素,并使用指定的回调函数对每个元素进行转换或映射。该方法返回一个新的数组,新数组由对原始数组中的每个元素应用回调函数后的结果组成。
2.1 语法:
javascript
var newArray = array.map(function(currentValue, index, array) {
// 返回转换后的值
});
2.2 参数:
- currentValue:当前遍历的元素值。
- index(可选):当前遍历的元素索引。
- array(可选):正在被遍历的原始数组。
2.3 示例:
javascript
var numbers = [1, 2, 3, 4, 5];
var doubled = numbers.map(function(num) {
return num * 2; // 返回每个元素的两倍
});
console.log(doubled); // 输出新的数组 [2, 4, 6, 8, 10]
输出结果:
javascript
[2, 4, 6, 8, 10]
.map() 方法遍历数组中的每个元素,并将每个元素通过回调函数进行转换或映射。在上述示例中,我们返回了每个元素的两倍,并创建了一个新的数组。
3. 区别
3.1 返回值:
- .forEach() 方法没有返回值,它仅用于遍历数组并对每个元素执行操作,通常用于执行副作用(如修改数组或输出)。
- .map() 方法返回一个新的数组,该数组由对原始数组中的每个元素应用回调函数的结果组成,通常用于转换或映射数组的元素。
3.2 使用情况:
- .forEach() 方法适用于需要遍历数组并对每个元素执行操作,但不需要返回结果的情况。它是一种迭代数组的简单方法,通常用于执行循环中的副作用操作,如修改数组的元素或输出结果。
- .map() 方法适用于需要遍历数组并对每个元素进行转换或映射的情况。它返回一个新的数组,该数组包含对原始数组中每个元素应用回调函数后的结果。通常用于在不修改原始数组的情况下,生成一个新的数组,其中的元素经过转换、映射或计算。
3.3 示例
javascript
// 使用 forEach() 循环
var numbers = [1, 2, 3, 4, 5];
numbers.forEach(function(num) {
console.log(num * 2); // 输出每个元素的两倍
});
// 使用 map() 循环
var numbers = [1, 2, 3, 4, 5];
var doubled = numbers.map(function(num) {
return num * 2; // 返回每个元素的两倍
});
console.log(doubled); // 输出新的数组 [2, 4, 6, 8, 10]
在上述示例中,我们有一个名为 numbers 的数组。使用 .forEach() 方法,我们遍历数组并输出每个元素的两倍。而使用 .map() 方法,我们通过返回每个元素的两倍来创建一个新的数组。