首页 > 解决方案 > 在 puppeteer 中等待 page.waitFor inside page.evaluate?

问题描述

我想知道你是否可以做类似的事情

 page.evaluate((page) => {
     //Code to execute before
     await page.waitFor(1000);
     //Code to execute after the 1000ms time delay
 }, page);

如果这是不可能的,那么如何引入这样的时间延迟?

哦,最后一点,做这样的事情对于我的项目中的时间延迟来说不是一个可行的选择:

 function delay(time) {
     let curtime = new Date().getTime();
     time += curtime;
     while(curtime < time) {
         curtime = new Date().getTime();
     } 
 }

CPU对此很重要,我不想让一些while循环执行数千次以获得简单的延迟

标签: javascriptnode.jstimepuppeteer

解决方案


  1. await只能在async函数中使用。
  2. 函数 inevaluate将在页面上下文中进行评估,因此:

使用setTimeout()

page.evaluate(() => {
     //Code to execute before
     setTimeout(function() {
       //Code to execute after the 1000ms time delay
     }, 1000);    
 });

或者编写类似于puppeteerpage.waitFor的异步延迟函数。

function waitFor(delay) {
    return new Promise(resolve => setTimeout(resolve, delay));
}

然后你将拥有:

page.evaluate(async() => {
     //Define your waitFor function
     //Code to execute before
     await waitFor(1000);
     //Code to execute after the 1000ms time delay
 });

推荐阅读