トップページ > Selenium API(逆引き) > 【Ruby】drag_and_drop_by/perform

【Ruby】drag_and_drop_by/perform・・・要素を特定座標にドラッグ&ドロップする

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

「drag_and_drop_by」「perform」を連続で実行することで要素を特定座標にドラッグ&ドロップすることが出来ます。

下記サンプルでは、「drag_and_drop_by」のメソッドを実行しています。このメソッドは第1引数で指定した要素をクリックしそのままドラッグ状態にします。続いて第2引数で、第1引数(要素)のX座標からX方向にどれだけ移動させるか(オフセット)を指定します。第3引数も同様に、第1引数(要素)のY座標からY方向にどれだけ移動させるか(オフセット)を指定します。最後に「perform」を実行することで、これまでのメソッドをビルドした後、実行していきます。

※アクションについてはこちら

説明

◆メソッド
  ・drag_and_drop_by(element, xoffset, yoffset)        :要素を指定座標にドラッグ&ドロップ
  ・perform                        :処理の実行
◆使用形態
  ・driver.action.drag_and_drop_by(element, 100, 200).
                            perform
◆備考
  ・ドラッグ操作の"click_and_hold(element)"と座標指定の"move_by_offset(xoffset,yoffset)"
     とドロップ操作の"release"を1つにしたメソッド
◆関連項目
  ・キーボードを押しながら要素をクリックをする
  ・押下したキーボードを指定したタイミングで離す

サンプル

require 'selenium-webdriver'
 
# Firefoxを起動
driver = Selenium::WebDriver.for(:firefox)
#指定したURLに遷移する
driver.get('https://jqueryui.com/draggable/')
#要素がロードされるまでの待ち時間を30秒に設定
driver.manage.timeouts.implicit_wait = 30
#カレントウインドウを最大化する
driver.manage.window.maximize
#ドラッグ対象の要素が存在するフレームに切り替える
driver.switch_to.frame(0)
#IDが"draggable"の要素を取得(ドラッグ対象の要素)
element  = driver.find_element(:id, 'draggable')
#3秒間待機して移動前の位置を確認
sleep(3)
#要素をX方向に300ポイント,y方向に300ポイントドラッグアンドドロップさせる
driver.action.drag_and_drop_by(element,300,300).
              perform
※selenium version 4.1.0で動作確認をしています(ブラウザのUIや属性値などが変更された場合、実行結果が異なる可能性があります)

実行結果

dragAndDropBy
yajirushi
dragAndDropBy2

Fatal error: Uncaught Google_Service_Exception: Error calling GET https://www.googleapis.com/analytics/v3/data/ga?ids=ga%3A138132118&start-date=7daysAgo&end-date=yesterday&metrics=ga%3Apageviews&dimensions=ga%3ApageTitle%2C+ga%3ApagePath&sort=-ga%3Apageviews&max-results=1000: (403) User does not have sufficient permissions for this profile. in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php:110 Stack trace: #0 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(62): Google_Http_REST::decodeHttpResponse(Object(Google_Http_Request), Object(Google_Client)) #1 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Task/Runner.php(174): Google_Http_REST::doExecute(Object(Google_Client), Object(Google_Http_Request)) #2 /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php(46): Google_Task_Runner->run() #3 /home/users/1/monda-muki/web/seleniumqref in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110