亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Puppeteer 流程??邏輯,檢查導航是否發生(與等待)

Puppeteer 流程??邏輯,檢查導航是否發生(與等待)

尚方寶劍之說 2023-05-11 16:55:36
尋找一些反饋。在 Puppeteer 中,我想檢查導航是否已經發生,如果有則做一些事情,如果沒有發生則做其他事情(例如再試一次)。我想出的兩種方法是:if (await page.url() != finalURL) {    let t = 0;      busy: while(t > 400) {        try {            await Promise.all([                await page.click('#tryAgainLink'),                await page.waitForNavigation(),            ]);            break busy;        } catch(err) {            // navigation didn't happen            t++;            await page.waitForTimeout(1500);        }    }}但是我的理解是,嘗試/捕獲流邏輯并不理想。我的選擇是這樣的:let t = 0;busy: while(await page.url() != finalURL) {    await page.click('#tryAgainLink');    await page.waitForTimeout(1500);    t++;    if(t > 400) {        break busy;    }}我想知道我是否應該waitForNavigatin在那里,但如果沒有,我將不得不再次捕獲拋出的錯誤。我的意思是測試這個,但我不確定await page.url()while 循環是否會在導航發生時觸發幾次,和/或是否會破壞頁面上下文。有沒有比上面兩種方法更好的方法呢?第一個確實有效,我很想保持原樣。謝謝。
查看完整描述

3 回答

?
BIG陽

TA貢獻1859條經驗 獲得超6個贊

您應該能夠執行以下操作:


await page.waitForFunction((finalUrl) => {

  return document.location === finalUrl

}, {}, finalUrl).catch(retry)

但它可能更簡單:


await page.waitForResponse(finalUrl).catch(retry)


查看完整回答
反對 回復 2023-05-11
?
飲歌長嘯

TA貢獻1951條經驗 獲得超3個贊

也許是這樣的:


if (page.url() !== finalURL) { // await is not needed here

    let t = 0;

    busy: while(t < 400) { // was '> 400' a typo?

        const [_, navigation] = await Promise.allSettled([

            page.click('#tryAgainLink'),

            page.waitForNavigation(),

        ]);


        if (navigation.status === 'fulfilled') break busy;


        t++;

        await page.waitForTimeout(1500);

    }

}


查看完整回答
反對 回復 2023-05-11
?
莫回無

TA貢獻1865條經驗 獲得超7個贊

我使用這種方法:



async function isNavigation() {

  try {

    await page.evaluate(() => console.log('any code'))

    return false

  } catch (ex) {

    // check error, should be:

    // "Execution context was destroyed, most likely because of a navigation"

    return true

  }


}


查看完整回答
反對 回復 2023-05-11
  • 3 回答
  • 0 關注
  • 214 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號