[英]PUPPETER - Random timeout inside loop not working
所以,我有这样的代码(只有这部分不能正常工作)
(async () => {
const browser = await puppeteer.launch({
headless: false,
// slowMo: 250 // slow down by 250ms
});
const page = await browser.newPage();
//some code
// CODE ABOVE WORKS, here is what is not working inside of it:
await page.evaluate(() => {
function delay(timeout) {
return new Promise((resolve) => {
setTimeout(resolve, timeout);
});
}
function randomInteger(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
const farms = document.querySelectorAll(".startButton");
for (let i = 0; i < 3; i++) {
for (const farm of farms) {
farm.click();
}
delay(randomInteger(820000, 920000));
}
});
})();
我想要的是,到 select 与此 class 的所有按钮,单击它们,然后等待一段时间,然后再次单击它们,但它看起来像延迟 function 代码在这里,或其他部分未执行它工作得很好,我知道哪里有问题,我请求你的帮助::D
#编辑
代码(如@Sheun Aluko 所说,添加了异步和等待)很好,由于网站安全系统,它无法正常工作,所以我需要应用刷新/转到同一页面的新修复程序,并更改循环顺序,也许是它效率不高,但它可以 100% 工作。 这是示例:
(async () => {
const browser = await puppeteer.launch({
headless: false,
// slowMo: 250 // slow down by 250ms
});
//SOME CODE THAT WORKS
//OUR PART BELOW
for (let i = 0; i < 150; i++) {
await page.goto("SOME_URL", {
waitUntil: "networkidle2",
});
await page.evaluate(async (page) => {
function delay(timeout) {
return new Promise((resolve) => {
setTimeout(resolve, timeout);
});
}
function randomInteger(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
const farms = document.querySelectorAll('SOME_SELECTOR');
for (const farm of farms) {
farm.click();
}
await delay(randomInteger(840000, 960000));
});
}
})
我可以看到delay
function 返回 promise。 在最后一行,我相信您应该改为调用await delay(randomInteger(820000, 920000))
以便循环在下一次迭代之前实际等待。
针对您提到的错误,这是因为您传递给 page.evaluate 的 function 未标记为异步。 我对 Puppeteer 并不完全熟悉,但您可以尝试将提供的 function 标记为异步 .. 即:
await page.evaluate( async () => {
....
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.