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

【Java】dragAndDrop/perform・・・要素を他の要素へドラッグ&ドロップする

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

「dragAndDrop」「perform」を連続で実行することで要素を他の要素へドラッグ&ドロップすることが出来ます。

下記サンプルでは、Actionsクラスのインスタンス作成する為に、Actionsクラスのコンストラクタの引数に、対象driverを指定してインスタンスを作成しています。続いて作成したインスタンスに対して「dragAndDrop」のメソッドを実行しています。このメソッドは第1引数で指定した要素をドラッグ対象の要素とし、第2引数で指定した要素に対してドロップします。最後に「perform」を実行することで、これまでのメソッドをビルドした後、実行していきます。

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

説明

◆メソッド
  ・Actions dragAndDrop(WebElement source,WebElement target)
                         :要素を他の要素へドラッグ&ドロップ
  ・void perform()                :処理の実行
◆使用形態
  ・action.dragAndDrop(source,target)
                  .perform()
◆備考
  ・ドラッグ操作の"clickAndHold"と要素移動の"moveToElement"とドロップ操作の
       "release"を1つにしたメソッド
◆関連項目
  ・キーボードを押しながら要素をクリックする
  ・キーボードを押しながら特定座標をクリックする

サンプル

import java.time.Duration;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.interactions.Actions;

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://jqueryui.com/droppable/");
    //要素がロードされるまでの待ち時間を30秒に設定
    Duration waitTime = Duration.ofSeconds(30);
    driver.manage().timeouts().implicitlyWait(waitTime);
    //ドラッグ対象の要素が存在するフレームに切り替える
    driver.switchTo().frame(0);
    //移動元の要素と移動先の要素を取得
    WebElement source = driver.findElement(By.id("draggable"));
    WebElement target = driver.findElement(By.id("droppable"));
    //移動元の要素をドラッグし移動先の要素へドラッグアンドドロップ
    Actions action = new Actions(driver);
    action.dragAndDrop(source,target)
               .perform();
  }
}
※selenium version 4.1.4で動作確認をしています(ブラウザのUIや属性値などが変更された場合、実行結果が異なる可能性があります)

実行結果

dragAndDrop
yajirushi
dragAndDrop2

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