var datas = [
[1, 2, 3, 4],
[5, 6, 7, 8],
[9, 10, 11, 12],
[13]
]
// 模拟ajax请求
function upload (json) {
return new Promise(resolve => {
console.log('sendData: ', json)
setTimeout(() => {
resolve(json)
console.log('receiveData: ', json)
}, 2000)
})
}
datas.reduce(async (prev, cur, i) => {
let data = JSON.stringify(datas[i])
await prev
return upload(data) // this.$api.post封装成一个promise,前面一定要加return
}, Promise.resolve())
// sendData: [1,2,3,4]
// 2s后
// receiveData: [1,2,3,4]
// sendData: [5,6,7,8]
// 4s后
// receiveData: [5,6,7,8]
// sendData: [9,10,11,12]
// 6s后
// receiveData: [9,10,11,12]
// sendData: [13]
// 8s后
// receiveData: [13]
问题:
- this.$api.post封装成一个promise,前面一定要加return,不加return所有的请求一起都发出去了,就没有你说的前一个发送成功之后再发送后一个;
- result遍历了一遍,result[i]也是一个数组,你又reduce了一遍,你请求发送的是数组中每个元素的每个元素,一共8*4+1=33个请求。我觉得直接在result上应用reduce就行了,为什么要在每个子元素上应用reduce。
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…