「before_navigate_back/after_navigate_back/before_navigate_forward/after_navigate_forward」を実行することで、ブラウザの『戻る』または『進む』に対して直前/直後の処理を実施することが出来ます。
イベント処理をするためにまず初めにすることは、イベント捕捉クラスを定義することです。ここで、イベント捕捉クラスをMyListenerクラスと命名します。MyListenerクラスは、AbstractEventListenerクラスを継承して作成されたサブクラスです。AbstractEventListenerクラスの関数はダミー実装がされているためMyListenerクラスでイベントに対応した各関数をオーバーライドする必要があります。ここでは、「before_navigate_back/after_navigate_back/before_navigate_forward/after_navigate_forward」の関数の内容をオーバーライドしています。
それでは、実際にイベント発生させていきます。イベントを発生させる前に、Firefoxのインスタンスドライバに対してイベント捕捉クラスのインスタンスを渡します。そしてそのインスタンスドライバに対して、ページ遷移(GoogleTopページ)をした後、検索テキストボックスの要素を取得しています。
この段階では、「before_navigate_back/after_navigate_back/before_navigate_forward/after_navigate_forward」の関数が自動で呼び出される条件は満たしていません。これらの関数が自動で呼び出されるトリガーとなる操作(イベントが発生する操作)は、ブラウザの『戻る』または『進む』の操作がされた時です。そのため、「back」または「forward」が実行されたときに初めてイベントが発生し、操作前後のページタイトルがコンソール出力されます。
※イベント処理についてはこちら
説明
◆メソッド ・before_navigate_back(driver) ・after_navigate_back(driver) ・before_navigate_forward(driver) ・after_navigate_forward(driver) ◆使用形態 ・上記メソッドはあらかじめAbstractEventListenerクラスを継承して オーバーライドしておく。 ◆備考 ・このイベントはdriver.backメソッドまたは、 driver.forwardメソッド実行にて発生する ◆関連項目 ・URLが遷移する直前/直後の処理を実施する ・javascriptを実行する直前/直後の処理を実施する
サンプル
require 'selenium-webdriver' require './MyListener' require 'logger' #loggerを初期化する(標準出力へのログ) logger = Logger.new(STDOUT) #MyListenerクラスのインスタンスを作成 listener = MyListener.new(logger) #FirefoxのインスタンスドライバにMyListenerクラスのインスタンスを渡す driver = Selenium::WebDriver.for(:firefox, :listener => listener) #指定したURLに遷移する driver.get('https://www.google.co.jp') #「Gmail」へのリンクテキストの要素を取得 element = driver.find_element(:class_name,'gb_d') #「Gmail」のリンクテキストをクリックする element.click #ブラウザの『戻る』操作を実施 driver.navigate.back #ブラウザの『進む』操作を実施 driver.navigate.forward
class MyListener < Selenium::WebDriver::Support::AbstractEventListener #イベント捕捉クラス(MyListenerクラス)を定義する #MyListenerクラスはAbstractEventListenerクラスのサブクラス #AbstractEventListenerクラスでは関数がダミー実装されており、MyListenerクラスで関数をオーバーライドしていく def initialize(log) @log = log end #ブラウザの『戻る』直前の処理 def before_navigate_back(driver) @log.info("before_navigate_back:Title is #{driver.title}") end #ブラウザの『戻る』直後の処理 def after_navigate_back(driver) @log.info("after_navigate_back:Title is #{driver.title}") end #ブラウザの『進む』直前の処理 def before_navigate_forward(driver) @log.info("before_navigate_forward:Title is #{driver.title}") end #ブラウザの『進む』直後の処理 def after_navigate_forward(driver) @log.info("after_navigate_forward:Title is #{driver.title}") end end
実行結果
I, [2018-03-24T21:08:18.027216 #12776] INFO -- : before_navigate_back:Title is Gmail I, [2018-03-24T21:08:18.290217 #12776] INFO -- : after_navigate_back:Title is Google I, [2018-03-24T21:08:18.300217 #12776] INFO -- : before_navigate_forward:Title is Google I, [2018-03-24T21:08:19.033251 #12776] INFO -- : after_navigate_forward:Title is Gmail