异步任务:依次发送3次网络请求,拿到服务器数据
Sunny-117 opened this issue · 3 comments
Sunny-117 commented
异步任务:依次发送3次网络请求,拿到服务器数据
hyxieshi commented
function data1() {
return new Promise((res) => {
setTimeout(() => {
res("获取到第一条数据");
}, 3000);
});
}
function data2(data = "") {
return new Promise((res) => {
console.log(data);
setTimeout(() => {
res("获取到第二条数据");
}, 5000);
});
}
function data3(data = "") {
return new Promise((res) => {
console.log(data);
setTimeout(() => {
res("获取到第三条数据");
}, 1000);
});
}
function data4(data = "") {
return new Promise((res, rej) => {
console.log(data);
rej(new Error("失败"));
});
}
// 下一个接口需要上一个接口的数据 依次执行
data1()
.then((res) => {
return data2(res);
})
.then((res) => {
return data3(res);
})
.then((res) => {
return data4(res);
})
.catch((err) => {
console.log(err);
});
// 执行所有的异步任务 同时请求 成功
const promises = [data1(), data2(), data3()];
Promise.all(promises)
.then((res) => {
console.log("所有异步任务已成功加载");
console.log(res);
})
.catch((err) => {
console.log(err);
});
// 执行所有的异步任务 同时请求 失败
Promise.all([...promises, data4()])
.then((res) => {
console.log("所有异步任务已成功加载");
console.log(res);
})
.catch((err) => {
console.log(err);
});
rhwoodpecker commented
同时请求可以换种优雅的方式写法:
假设我们有3个请求,分别耗时一秒,在执行其他操作之前必须拿到三个结果,可以这么实现
const p1 = () => new Promise((resolve) => setTimeout(() => {
resolve("p1");
}, 1000))
const p2 = () => new Promise((resolve) => setTimeout(() => {
resolve("p2");
}, 1000))
const p3 = () => new Promise((resolve) => setTimeout(() => {
resolve("p3");
}, 1000))
const fn = async () => {
const r1 = p1()
const r2 = p2()
const r3 = p3()
const res1 = await r1
const res2 = await r2
const res3 = await r3
console.log(res1, res2, res3)
}
Archill311 commented
这个应该是实现的promise.all的功能吧 貌似题目要求是要依赖上一个请求的结果