DaysOfCode の日

Patricia Arquette
Patricia Arquetteオリジナル
2024-10-04 06:19:02335ブラウズ

Day of DaysOfCode

やあ!前回のエントリーからしばらく時間が経ってしまいました。
最近、私はループ内での要素参照の喪失に関連する問題に取り組んできました。そして、ついに解決策を見つけたので、皆さんと共有したいと思います。

達成したかったこと

  • 特定の Web ページ上のボタン要素を収集します。
  • 各ボタンをクリックして別のページに移動します。
  • 新しいページで特定のアクションを実行した後、最初のページに戻ります。
  • すべてのボタンをクリックするまで、手順 2 と 3 を繰り返します。

これは、最初のコードの簡略版です:

const someElements = await page.$$("xpath/ .//foo[@name='hoge']");

for (let i=0; i < someElements.length; i++) {
    await Promise.all([
        someElements[i].click(),
        page.waitForNavigation({ waitUntil: ["load", 'networkidle0'] }),
    /* There are particular processes and going back process */
    ]);
};

遭遇したエラー

forst ループの反復の後、スクリプトはボタン要素を見つけることができませんでした。次のエラーが繰り返し発生しました:
ProtocolError: プロトコル エラー (DOM.describeNode): で指定された ID のコンテキストが見つかりません

どうやって解決したか

ループ内でボタン要素リストを再宣言することで、この問題を解決しました。
変更されたコードは次のとおりです:

const someElements1 = await page.$$("xpath/ .//foo[@name='hoge']");

for (let i=0; i < someElements.length; i++) {
    const someElements2 = await page.$$("xpath/ .//foo[@name='hoge']"); // added row
    await Promise.all([
        someElements2[i].click(),
        page.waitForNavigation({ waitUntil: ["load", 'networkidle0'] }),
    /* There are particular processes and going back process */
    ]);
};

最初のページから移動するときに元の someElements 参照が失われると考えたので、再宣言行を追加しました。この変更後、エラーは解決されました。ただし、このアプローチがコーディングのベストプラクティスに厳密に準拠しているかどうかはわかりません。

ページ間を移動するときにループ内の .click() で問題が発生した場合は、ループ自体内で要素を再宣言することを検討してください。この簡単な変更により、トラブルシューティングの時間を大幅に節約できる可能性があります!

以上がDaysOfCode の日の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。