Браузер Puppeteer и мгновенное закрытие страницы, page.evaluate не работает на blo c 2 - PullRequest
0 голосов
/ 29 апреля 2020

У меня есть этот сценарий, все работает до начала блока 2 Я не понимаю, почему он не выполняет работу в блоке 2, я должен получить возврат в «page.on запрос», но это не тот случай уходит напрямую, у вас есть представление о проблеме?

узел не возвращает мне ошибки

спасибо

async function main() {
    const browser = await puppeteer.launch({headless: false});
    const page = await browser.newPage();
    await page.setViewport({width: 1200, height: 720})
    await page.goto('https://site.local', { waitUntil: 'networkidle0' }); // wait until page load
    await page.type("input[name='UserName']", "myusername");
    await page.type("input[name='Password']", "mypassworduser");
    // click and wait for navigation
    await Promise.all([
            page.click("body > main > button"),
            page.waitForNavigation({ waitUntil: 'networkidle0' }),
    ]);

    await page.goto(urlformation);

    await page.setRequestInterception(true);

    await page.on('request', (request) => { 
      if (request.resourceType() === 'media') {
        var CurrentRequest  = request.url();
        console.log(CurrentRequest);
        fs.appendFileSync(fichiernurlaudio, request.url()+"\r\n"); 
      }
      request.continue();

    }); 
//START BLOC 1 ------------------IT WORK    
    const Titresaudios = await page.evaluate(() => {
        let names = document.querySelectorAll(
            "td.cursor.audio"
        );
        let arr = Array.prototype.slice.call(names);
        let text_arr = [];
        for (let i = 0; i < arr.length; i += 1) {
            text_arr.push($vartraited+"\r\n");
        }
        return text_arr;
    })
    fs.appendFileSync(fichiernomaudio, Titresaudios);
//END BLOCK 1------------------IT WORK- i got data in my file   

//START BLOCK 2-------seems to ignore-----------NOT WORKING
    await page.evaluate(()=>{

        let elements = document.querySelectorAll("td.cursor.audio");    

        elements.forEach((element, index) => {
                setTimeout(() => {
                    element.click();
                }, index * 1000);  
        })

    })
//END BLOCK 2---------seems to ignore---------NO WORKING 

//i should see some console.log in page.on('request' (request) => { but instant close after works of bloc 1


    await page.close();
    await browser.close();


}

main();

1 Ответ

0 голосов
/ 29 апреля 2020

Понятия не имею, чего именно вы пытаетесь достичь, но этот блок можно переписать так:

// ...
const els = await page.$$( 'td.cursor.audio' );
for( const el of els ) {

  // basically your timeout, but from outside the browser
  await page.waitFor( 1000 );

  // perform the action
  await el.click();

}
// ...

В вашем скрипте единственное, что вы сделали в вызове evaluate(), было запланировать несколько тайм-аутов. Как только они были запланированы (но не выполнены!), Обратный вызов evaluate() завершается, и ваш скрипт продолжает работу с закрытием браузера. Скорее всего, ваши клики никогда не выполнялись.


По моему опыту, обычно рекомендуется делать как можно больше в NodeJS, а не в браузере. Обычно также облегчает отладку.

...