我编写了这段代码来迭代具有特定数字(如分页)的 github 问题,在这种情况下,一次有 3 个问题:
const getUrl = (page) => `https://api.github.com/repos/angular/angular/issues?page=${page}`;
const getIssues = async function*() {
for (let p = 1; true; p++) {
const url = getUrl(p);
const rawData = await fetch(url, {
headers: { 'User-Agent': 'app' }
});
const issues = await rawData.json();
for (let issue of issues) {
yield issue;
}
}
};
const generator = getIssues();
document.querySelector('[data-next]').addEventListener('click', async function() {
let i = 0;
for await (let issue of generator) {
console.log(issue);
if (++i === 3) break;
}
console.log(await generator.next());
});
具有 data-next 属性的元素是一个按钮。预期的行为是每次单击按钮都会加载接下来的 3 个问题。问题是,生成器在中断后完成(console.log 打印:){value: undefined, done: true}
。
为什么它完成了,我怎样才能按预期完成这项工作?