如何在使用 fetch 时在 for 循环中动态循环多个 promise?
How to loop dynamically over multiple promises in a for loop while using fetch?
这是有效的方法:
const limit = 1000
// fetchMyProducts(page, limit, flag)
return fetchMyProducts(1, 1, true)
.then(function (products) {
return fetchMyProducts(2, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(3, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(4, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(5, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(6, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(7, limit, false)
})
我正在尝试通过fetch 获取我们系统中的所有产品。
问题是,目前,我知道有多少产品,但 1 年/3 年...谁知道??
我正在尝试动态循环获取所有产品。
我已经试过了,但是它似乎根本没有被调用。
return fetchMyProducts(1, 1, true)
.then(function (numberOfProducts) {
let pages = Math.ceil(numberOfProducts / 1000) + 1;
console.log(pages);
return getAllProducts = () => {
for (let i = 1; i < pages; i++) {
const element = array[i];
return fetchMyProducts(2, limit, false)
}
}
}).then(... something else)
有没有办法在完成后循环获取承诺和 return 某些东西,然后继续做其他事情?
您正在寻找
const limit = 1000
let chain = Promise.resolve();
for (let i=1; i<8; i++) {
chain = chain.then(function(products) {
return fetchMyProducts(i, limit, false)
});
}
return chain;
动态构建您拼写的承诺链。
要获得更简单有效的解决方案,请考虑使用 async
/await
:
const limit = 1000
for (let i=1; i<8; i++) {
const products = await fetchMyProducts(i, limit, false);
}
return;
这是有效的方法:
const limit = 1000
// fetchMyProducts(page, limit, flag)
return fetchMyProducts(1, 1, true)
.then(function (products) {
return fetchMyProducts(2, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(3, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(4, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(5, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(6, limit, false)
}).then(function (totalProducts) {
return fetchMyProducts(7, limit, false)
})
我正在尝试通过fetch 获取我们系统中的所有产品。 问题是,目前,我知道有多少产品,但 1 年/3 年...谁知道??
我正在尝试动态循环获取所有产品。
我已经试过了,但是它似乎根本没有被调用。
return fetchMyProducts(1, 1, true)
.then(function (numberOfProducts) {
let pages = Math.ceil(numberOfProducts / 1000) + 1;
console.log(pages);
return getAllProducts = () => {
for (let i = 1; i < pages; i++) {
const element = array[i];
return fetchMyProducts(2, limit, false)
}
}
}).then(... something else)
有没有办法在完成后循环获取承诺和 return 某些东西,然后继续做其他事情?
您正在寻找
const limit = 1000
let chain = Promise.resolve();
for (let i=1; i<8; i++) {
chain = chain.then(function(products) {
return fetchMyProducts(i, limit, false)
});
}
return chain;
动态构建您拼写的承诺链。
要获得更简单有效的解决方案,请考虑使用 async
/await
:
const limit = 1000
for (let i=1; i<8; i++) {
const products = await fetchMyProducts(i, limit, false);
}
return;