for, forEach和map的区别

在开发过程中,经常需要对数组进行遍历。我们可以使用 for, forEach 和 map 来实现对数组的遍历,他们各自有什么特点?让我们来一探究竟。

for

基本使用 (以for…of为例)
const arr = [1, 2, 3]
for (let item of arr) {
	console.log(item)
}
// 1
// 2
// 3
特性

1.可以使用 break 提前终止遍历。

const arr = [1, 2, 3]
for (let item of arr) {
	if (item > 1) {
		break
	}
	console.log(item)
}
// 1

2.可以使用 continue 来跳过当前的循环。

const arr = [1, 2, 3]
for (let item of arr) {
	if (item === 2) {
		continue
	}
	console.log(item)
}
// 1
// 3

forEach

基本使用
const arr = [1, 2, 3]
arr.forEach((item) => {
    console.log(item)
})
// 1
// 2
// 3
特性

1.不能通过 continue 跳过循环,想跳过循环需要使用 return。

const arr = [1, 2, 3];
arr.forEach((item) => {
  if (item === 2) {
    return;
  }
  console.log(item);
});

2.forEach 没有返回值,返回值为 undefined。

const arr = [1, 2, 3];
let res = arr.forEach((item) => {
  console.log(item);
  return item
});
console.log(res) // undefined
// 1
// 2
// 3

map

基本使用
const arr = [1, 2, 3];
arr.map((item) => {
  console.log(item)
});
// 1
// 2
// 3
特性

1.遍历数组不改变数组本身。

const arr = [1, 2, 3];
arr.map((item) => {
  // 将每个元素的值增加 1
  item = item + 1
});
console.log(arr) // [1, 2, 3]

2.有返回值,返回一个新的数组。

const arr = [1, 2, 3];
let res = arr.map((item) => {
  return item
});
console.log(res) // [1, 2, 3]

3.如需返回元素,必须通过 return,否则返回的元素为 undefined

const arr = [1, 2, 3];
let res = arr.map((item) => {
  // 当元素大于 1 时,返回该元素
  if(item > 1) {
    return item
  }
});
console.log(res) // [undefined, 2, 3]

在以上的例子中,在 item 值为1时,没有 return 值,所以 map 返回数组的映射(对应)的值为 undefined。

for, forEach 和 map 的区别
  1. 中止循环。for 通过 break 关键字来中止循环,forEach 和 map 不可以。
  2. 跳过此次循环。for 通过 continue 来跳过,forEach 通过 return 跳过,map 不能跳过。
  3. 返回值。map 返回一个数组,在 map 的回调函数中,不使用 return 返回值的话,会返回 undeifned。for 和 forEach 没有返回值。
  4. 改变原数组。map 不改变原数组,for 和 forEach 可以改变原数组。
  5. 代码量。for 的代码量比 forEach 和 map 要多。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C知道:forEachmap和for循环都是用于遍历数组的方法,但它们有一些区别。 1. forEachforEach是一个数组方法,它接受一个回调函数作为参数,并且对数组中的每个元素都执行一次回调函数。forEach不会返回任何值,它主要用于对数组进行遍历和执行副作用操作,比如修改数组中的元素或输出结果。例如: ```javascript const array = [1, 2, 3]; array.forEach((element) => { console.log(element); }); ``` 2. mapmap也是一个数组方法,它接受一个回调函数作为参数,并且对数组中的每个元素都执行一次回调函数。不同于forEachmap会返回一个新的数组,该数组包含了回调函数的返回值。map方法通常用于根据原始数组生成一个新的数组,而不会修改原始数组。例如: ```javascript const array = [1, 2, 3]; const newArray = array.map((element) => { return element * 2; }); console.log(newArray); // [2, 4, 6] ``` 3. for循环:for循环是一种传统的遍历方式,它通过控制变量的增量来遍历数组。相比于forEachmap方法,for循环更加灵活,并且可以在循环过程中进行更多的操作。例如: ```javascript const array = [1, 2, 3]; for (let i = 0; i < array.length; i++) { console.log(array[i]); } ``` 总结:forEachmap方法是对数组进行遍历的两种方式,其中forEach主要用于执行副作用操作,而map主要用于生成新的数组。for循环是一种传统的遍历方式,更加灵活,可以在循环过程中进行更多的操作。具体使用哪种方法取决于具体的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值