如何使用 NodeJS 在 puppeteer 中迭代异步函数

How to iterate async function in puppeteer with NodeJS

我想用 puppeteer 截屏,它对一个 post 有效。但我想让它迭代。

如果是普通函数我可以直接把函数名写在代码的最后面这样就可以迭代了。但这是异步函数,所以我不知道如何迭代它。

const puppeteer = require('puppeteer');

let postNumber = 1;
let by;

(async () => {
    const browser = await puppeteer.launch({
        executablePath: 'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe',
        userDataDir: 'C:\Users\{computerName}\AppData\Local\Google\Chrome\User Data',
        headless: false
    }); // default is true
    const page = await browser.newPage();
    await page.goto(`https://band.us/band/{someNumbers}/post/${postNumber}`, {
        waitUntil: 'networkidle2'
    });
    let element = await page.$('.boardList');
    by = await page.evaluate(() => document.getElementsByClassName('text')[0].textContent);
    console.log(by);

    await element.screenshot({
        path: `./image/${postNumber}-${by}.png`
    });
    console.log(`SAVED : ${postNumber}-${by}.png`)
    postNumber++;
    await browser.close();
})();

函数完成后,postNumber 变量应该加一。然后 运行 通过新的 URL 再次输入代码。

如果您想 运行 代码一个接一个地迭代,可以使用普通的 for(或 while)循环。 async/await 代码适用于这些。

您可以像这样在您的案例中使用 for:

(async () => {
    const browser = await puppeteer.launch(/* ... */);
    const page = await browser.newPage();

    for (let postNumber = 1; postNumber < 10; postNumber++) {
        await page.goto(/* ... */);
        let element = await page.$('.boardList');
        // ...
    }

    await browser.close();
})();

您可以使用任何合适的循环,例如 while-loop:

'use strict';

const puppeteer = require('puppeteer');

(async () => {
    const browser = await puppeteer.launch({
        executablePath: 'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe',
        userDataDir: 'C:\Users\{computerName}\AppData\Local\Google\Chrome\User Data',
        headless: false
    }); // default is true
    const page = await browser.newPage();

    let postNumber = 1;
    while (postNumber <= 10) {
      await page.goto(`https://band.us/band/{someNumbers}/post/${postNumber}`, {
          waitUntil: 'networkidle2'
      });
      const element = await page.$('.boardList');
      const by = await page.evaluate(() => document.getElementsByClassName('text')[0].textContent);
      console.log(by);

      await element.screenshot({
          path: `./image/${postNumber}-${by}.png`
      });
      console.log(`SAVED : ${postNumber}-${by}.png`)
      postNumber++;
    }

    await browser.close();
})();