Java WebDriver から JavaScript コードを実行するにはどうすればよいですか?

Patricia Arquette
リリース: 2024-10-25 04:50:29
オリジナル
486 人が閲覧しました

How do I Execute JavaScript code from Java WebDriver?

Java から WebDriver JavaScript を実行する: 拡張ガイド

質問で言及されているコマンド ./go webdriverjs は、設計されたシェル コマンドです。特定のフォルダーに WebDriverJs 環境をセットアップして初期化します。ただし、WebDriverJs は、Java から JavaScript スニペットを実行するのではなく、JavaScript テストを可能にする言語バインディングであることに注意することが重要です。

Java WebDriver 内で JavaScript コードを実行するには、次のアプローチを利用します。

<code class="java">WebDriver driver = new AnyDriverYouWant();
if (driver instanceof JavascriptExecutor) {
    ((JavascriptExecutor)driver).executeScript("yourScript();");
} else {
    throw new IllegalStateException("This driver does not support JavaScript!");
}</code>
ログイン後にコピー

代わりに、次のことを検討してください。

<code class="java">WebDriver driver = new AnyDriverYouWant();
JavascriptExecutor js;
if (driver instanceof JavascriptExecutor) {
    js = (JavascriptExecutor)driver;
} // else throw...

// later on...
js.executeScript("return document.getElementById('someId');");</code>
ログイン後にコピー

JavaScriptExecutor は、広範なドキュメントと機能を提供します。そのexecuteScript()メソッドでは、関数呼び出し、生のJS、戻り値を実行し、複雑な引数を渡すことができます。

例:

  1. driver.findElement( By.id("someId")):
<code class="java">js.executeScript("return document.getElementById('someId');");</code>
ログイン後にコピー
  1. WebElement の境界線の視覚化:
<code class="java">WebElement element = driver.findElement(By.anything("tada"));
js.executeScript("arguments[0].style.border='3px solid red'", element);</code>
ログイン後にコピー
  1. ラジオへのページ入力の変更ボタン:
<code class="java">js.executeScript(
         "var inputs = document.getElementsByTagName('input');" +
         "for(var i = 0; i < inputs.length; i++) { " +
         "    inputs[i].type = 'radio';" +
         "}" );</code>
ログイン後にコピー

以上がJava WebDriver から JavaScript コードを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!