相关疑难解决方法(0)

如何避免“框架分离”错误异步验证或使用 Puppeteer 进行重定向?

之前的答案为我指明了方向,即如何捕获异步验证错误或重定向。但在我的场景中, aniframe开始发挥作用,它让我整天忙碌。一些指向正确方向的指针会非常有帮助,因为我无法做到正确,尽管错误清楚地说明了哪里出了问题。

场景的:

  1. 输入留空。在 iframe 内单击按钮,异步请求返回验证错误
  2. 输入有一个值。单击 iframe 内的按钮,用户将被重定向到显示“yaay”的页面。

第二种情况中抛出的错误指出waitForFunction failed: frame got detached。这是有道理的,因为框架不再存在......我发现了,frame.isDetached()但仍然不断抛出相同的错误。我缺少什么或者如何使用此方法使其发挥作用?

let frame = (await page.frames())[0];
...
for (let action of actions) {
    if (action.type === '...') {
        // ...
    }

    if (action.type === 'click') {
        frame.click("#btn");        

        // works for scenario 1 
        await Promise.race([
            page.waitForNavigation({ waitUntil: "networkidle2" }),
            // ERROR THROWN HERE FOR SCENARIO 2
            // `waitForFunction failed: frame got detached`

            // the line below doesn't seem to work …
Run Code Online (Sandbox Code Playgroud)

javascript iframe puppeteer

7
推荐指数
0
解决办法
9236
查看次数

标签 统计

iframe ×1

javascript ×1

puppeteer ×1