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

【Java】beforeNavigateBack/afterNavigateBack/beforeNavigateForward/ afterNavigateForward・・・ブラウザの『戻る』または『進む』に対して直前/直後の処理を実施する

「beforeNavigateBack/afterNavigateBack/beforeNavigateForward/afterNavigateForward」を実行することで、ブラウザの『戻る』または『進む』に対して直前/直後の処理を実施することが出来ます。

イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをExEventListnerクラスと命名します。ExEventListnerクラスは、AbstractWebDriverEventListenerクラスを継承して作成されたサブクラスです。AbstractWebDriverEventListenerクラスの関数はダミー実装がされているためExEventListnerクラスでイベントに対応した各関数をオーバーライドする必要があります。ここでは、「beforeNavigateBack/afterNavigateBack/beforeNavigateForward/afterNavigateForward」の関数の内容をオーバーライドしています。

イベントを発生させる前にいくつかやるべきことがあります。まずイベント発生クラスである「EventFiringWebDriver」コンストラクタにWebDriverのインスタンスを指定して、イベント発生クラスのインスタンスを作成していきます。次にイベント捕捉クラスに対しても、newでインスタンスを作成します。そしてイベント発生クラスのregister関数で、引数にイベント捕捉クラスのインスタンスを指定することで、イベント発生がイベント捕捉クラスに通知できるようになります。

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

この段階では、「beforeNavigateBack/afterNavigateBack/beforeNavigateForward/afterNavigateForward」の関数が自動で呼び出される条件は満たしていません。この関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、ブラウザの『戻る』または『進む』の操作がされた時です。そのため、「back」または「forward」が実行されたときに初めてイベントが発生し、操作前後のページタイトルがコンソール出力されます。

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

説明

◆メソッド
  ・public void beforeNavigateBack(WebDriver driver)
  ・public void afterNavigateBack(WebDriver driver)
  ・public void beforeNavigateForward(WebDriver driver)
  ・public void afterNavigateForward(WebDriver driver)
◆使用形態
  ・上記メソッドはあらかじめAbstractWebDriverEventListenerクラスを継承して
         オーバーライドしておく。
◆備考
  ・このイベントはdriver.navigate().back()メソッドまたは、
    driver.navigate().forward()メソッド実行にて発生する
◆関連項目
  ・URLが遷移する直前/直後の処理を実施する
  ・javascriptを実行する直前/直後の処理を実施する

サンプル

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();
    //対象のWebDriverをイベント発生クラスに渡しインスタンスを作成する
    EventFiringWebDriver eventFiringDriver = new EventFiringWebDriver(driver);
    //イベント捕捉クラスのインスタンスを作成する
    ExEventListner eventListener = new ExEventListner();
    //イベント捕捉クラスをイベント発生クラスへ登録する
    eventFiringDriver.register(eventListener);
    //指定したURLへ遷移する
    eventFiringDriver.get("https://www.google.co.jp");
    //Gmailリンクテキストの要素を取得する
    WebElement element = eventFiringDriver.findElement(By.className("gb_P"));
    //Gmailリンクテキストをクリックする
    element.click();
    //ブラウザの『戻る』操作を実施
    eventFiringDriver.navigate().back();
    //ブラウザの『進む』操作を実施
    eventFiringDriver.navigate().forward();
  }
}
public class ExEventListner extends AbstractWebDriverEventListener {
  //ブラウザの『戻る』直前の処理
  @Override
  public void beforeNavigateBack(WebDriver driver){
    System.out.println("beforeNavigateBack:Title is " + driver.getTitle());
  }
  //ブラウザの『戻る』直後の処理
  @Override
  public void afterNavigateBack(WebDriver driver){
    System.out.println("afterNavigateBack:Title is " + driver.getTitle());
  }
  //ブラウザの『進む』直前の処理
  @Override
  public void beforeNavigateForward(WebDriver driver){
    System.out.println("beforeNavigateForward:Title is " + driver.getTitle());
  }
  //ブラウザの『進む』直後の処理
  @Override
  public void afterNavigateForward(WebDriver driver){
    System.out.println("afterNavigateForward:Title is " + driver.getTitle());
  }
}

実行結果

beforeNavigateBack:Title is Gmail
afterNavigateBack:Title is Google
beforeNavigateForward:Title is Google
afterNavigateForward:Title is Gmail
navigate
 ※GoogleおよびGoogleロゴはGoogle Inc.の登録商標であり、同社の許可を得て使用しています。

カテゴリー

Selenium導入

APIリファレンス

その他

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