トップページ > Selenium API(逆引き) > 【Java】beforeExecuteScript/afterExecuteScript

【Java】beforeExecuteScript/afterExecuteScript・・・javascriptを実行する直前/直後の処理を実施する

【PR】業界トップクラスの「高単価報酬」「低マージン」を実現!レバテックフリーランス

「beforeExecuteScript/afterExecuteScript」を実行することでjavascriptを実行する直前/直後の処理を実施することが出来ます。

イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをDriverEventListenerクラスと命名します。DriverEventListenerクラスは、 WebDriverListenerインターフェースを継承して作成されたサブクラスです。DriverEventListenerクラスでイベントに対応した各関数をオーバーライドします。ここでは、「beforeExecuteScript/afterExecuteScript」の関数の内容をオーバーライドしています。

イベントを発生させる前にやるべきことがあります。イベント発生クラスである「EventFiringDecorator」コンストラクタの引数にイベント捕捉クラスとWebDriverのインスタンスを指定して、イベント発生クラスのインスタンスを作成する必要があります。そうすることでイベント発生がイベント捕捉クラスに通知できるようになります。

それでは、実際にイベント発生させていきます。イベント発生は、イベント発生クラスのインスタンスに対して操作することで発生させていきます。下記サンプルではページ遷移(GoogleTopページ)をしています。

この段階では、「beforeExecuteScript/afterExecuteScript」の関数が自動で呼び出される条件は満たしていません。この関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、javascriptが実行された時です。そのため、下記サンプルを例にすると、Alertが表示されて初めてイベントが発生し、「beforeExecuteScript/afterExecuteScript」が実行されます。

※イベント処理についてはこちら

説明

◆メソッド
  ・public void beforeExecuteScript(WebDriver driver, java.lang.String script, java.lang.Object[] args)
  ・public void afterExecuteScript(WebDriver driver, java.lang.String script, java.lang.Object[] args, java.lang.Object result)
◆使用形態
  ・上記メソッドはあらかじめWebDriverListenerインターフェースを継承して
         オーバーライドしておく。
◆備考
  ・このイベントはexecuteScript(java.lang.String,java.lang.Object[])
         メソッド実行にて発生する

◆関連項目
  ・要素がクリックされる直前/直後の処理を実施する
  ・要素に値が入力される直前/直後の処理を実施する

サンプル

import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.events.EventFiringDecorator;
import org.openqa.selenium.support.events.WebDriverListener;

public class WebTest {
  public static void main(String[] args){
    //Chrome制御のためChromeDriverのパスを指定
    System.setProperty("webdriver.chrome.driver",
                                    "D:\\AutoTest\\chromedriver.exe");
    //Chromeを起動する
    WebDriver driver = new ChromeDriver();
    //指定したURLを開く
    driver.get("https://www.google.co.jp");
    //イベント捕捉クラスのインスタンスを作成する
    WebDriverListener eventListener = new DriverEventListener();
    //対象のWebDriverとイベント捕捉クラスをイベント発生クラスへ登録する
    WebDriver decorated = new EventFiringDecorator(eventListener).decorate(driver);
    //Javascriptを実行する
    ((JavascriptExecutor)decorated).
                             executeScript("window.alert('Test finished!');");
  }
}
import org.openqa.selenium.Alert;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.support.events.WebDriverListener;

public class DriverEventListener implements WebDriverListener{
  //Javascript実行直前の処理
  @Override
  public void beforeExecuteScript(WebDriver driver, java.lang.String script, java.lang.Object[] args) {
    System.out.println("beforeExecuteScript:Alert is not displayed!");
  }
  //Javascript実行直後の処理
  @Override
  public void afterExecuteScript(WebDriver driver, java.lang.String script, java.lang.Object[] args, java.lang.Object result) {
    Alert text = driver.switchTo().alert();
    System.out.println("afterExecuteScript:Text is 「" + text.getText() + "」");
  }
}
※selenium version 4.1.4で動作確認をしています(ブラウザのUIや属性値などが変更された場合、実行結果が異なる可能性があります)

実行結果

beforeExecuteScript:Alert is not displayed!
afterExecuteScript:Text is 「Test finished!」
ExecuteScript
 ※GoogleおよびGoogleロゴはGoogle Inc.の登録商標であり、同社の許可を得て使用しています。

Warning: Invalid argument supplied for foreach() in /home/users/1/monda-muki/web/seleniumqref.com/api/java/event/Java_Script.html on line 199

JavaAPIアクセス TOP10
過去1週間(4/18~4/24)

    カテゴリー

    環境構築

    APIリファレンス

    その他

    ページ上部へ戻る
    トップページ > Selenium API(逆引き) > 【Java】beforeExecuteScript/afterExecuteScript
    Copyright © 2016- Seleniumクイックリファレンス All Rights Reserved