js 数组for循环请求接口,并把返回数据放进新数组

需求:用一个数组中的每个值去循环请求接口,获取对应数据放进新数组

举个栗子可能更好理解:老师想知道每个同学的成绩,然后有个接口是需要用同学的id去拿到对应的分数。

那么,已知数组是:

[1, 2, 3, 4] // 同学id数组

目标数组是:

[
	{ id: 1, name: '张三', score: 98 },
	{ id: 2, name: '李四', score: 99 },
	{ id: 3, name: '王五', score: 99 },
	{ id: 4, name: '老六', score: 100 },
]

解决:

使用 asyncawait


methods: {
	async handleGoods(arr) {
      	let idArr = [1, 2, 3, 4];
		let scoreArr = [];
		for (let i = 0; i < idArr.length; i++) {
	  		let data = await this.getScore(i);
	  		scoreArr.push({
	    		id: idArr[i],
	    		name: data.name,
	    		score: data.score,
	  		})
		}
    },
    
	async getScore(id) {
		return await new Promise((resolve, reject) => {
			// 请求接口
			getScore({
				id: id,
        	}).then(res => {
          		resolve(res.data);
        	}).catch(() => {
          		reject({});
        	})
      	});
    },
}

总结:

要在循环中使用asyncawait,可以使用for…of 或者 for 循环, while循环等,不能使用foreach,因为在 forEarch 里执行 await 会并行的。

相关资料:

# 有了for循环 为什么还要forEach?#

# forEach的介绍 #

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
JavaScript中,使用for循环遍历数组是一种常见的方法。可以通过循环变量逐一访问数组元素。下面是一个示例代码: const arr = [1, 2, 3, 4, 5]; for (let i = 0; i < arr.length; i++) { console.log(arr[i]); } 这段代码中,我们定义了一个数组arr,然后使用for循环遍历数组中的每个元素,并通过console.log打印出来。循环变量i从0开始,每次循环递增1,直到i小于数组长度为止。在循环体内,通过arr[i]可以获取到当前循环数组元素。这样就可以依次访问数组中的每个元素了。[1] 除了上述常规的for循环,还可以使用其他的for循环形式来遍历数组。例如,可以使用forEach方法来遍历数组,它提供了更简洁的语法: const arr = [1, 2, 3, 4, 5]; arr.forEach(function(element) { console.log(element); }); 这段代码中,我们用了数组forEach方法,传入一个回函数作为参数。回函数中的element参数表示当前遍历的数组元素,通过console.log(element)可以打印出每个元素。forEach方法会自动遍历数组中的每个元素,并依次执行回函数。[2] 另外,还可以使用for...of循环遍历数组,它提供了更简洁的语法: const arr = [1, 2, 3, 4, 5]; for (let element of arr) { console.log(element); } 这段代码中,我们使用for...of循环遍历数组arr,每次循环将当前元素赋值给变量element,然后通过console.log(element)打印出来。for...of循环会自动遍历数组中的每个元素,并依次执行循环体。[3] 总结起来,JavaScript中可以使用for循环forEach方法或for...of循环遍历数组,根据实际需求选择合适的方式即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mossbaoo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值