1. 程式人生 > >Java Selenium Actions模擬滑鼠拖動dragAndDrop總結

Java Selenium Actions模擬滑鼠拖動dragAndDrop總結

滑鼠拖動API

Actions action = new Actions(webdriver);
##source-要拖動的元素A,target-拖動元素A到達的目標元素
action.dragAndDrop(source, target);
##source-要拖動的元素A,拖動元素移動多少,標準以元素A左上角為準,拖動元素相對元素A移到右邊是x是正值,左邊是負值,拖動元素相對元素A移到上邊是y是負值,下邊是正值,
action.dragAndDropBy(source, xOffset, yOffset);

eg:

//找到我們所要拖動的元素A
WebElement A = driver.findElement
(By.xpath("//*[@id=\"ext-gen153\"]/li[1]/div")); WebElement B=driver.findElement(By.xpath("//*[@id=\"ext-gen153\"]/li[2]/div")); Actions action = new Actions(driver.getDriver()); //滑鼠拖動A向左移動530,之後釋放滑鼠 action.dragAndDropBy(A, -570, 0).perform(); // 滑鼠拖動B向下移動100,向左移動570之後釋放滑鼠 action.dragAndDropBy(k2, -570, 100).perform
(); ##注意:拖動元素之間最好加強制休眠時間,否則不定時出問題,也不報錯,有你哭的 action.dragAndDrop(A, B).perform(); driver.sleep(2000); action.dragAndDrop(B, A).perform();

有時定位沒問題,程式碼沒問題,就是沒效果,那就考慮一下拖拽在不同的瀏覽器的工作效果

For firefox :  

Actions builder = new Actions(driver);  
builder.moveToElement(draggable).clickAndHold();  
builder.moveToElement
(target).click().perform(); For chrome : Actions builder = new Actions(driver); builder.moveToElement(draggable).clickAndHold(draggable); builder.moveToElement(target).release(target).perform();

重中之重:

拖動元素有一個最重要的前提是,你定位的xpath等一定要準確,否則,到時候會出現各種拖動錯亂的問題:

eg

1.拖動元素如果用到action.dragAndDropBy(k2, -570, 100).perform();比如,如果我們想把A元素(可能為圖示)拖動到B區域可能用到這個方法,但是把A拖動到B區域之後,如果我們又想把此時的A拖動到其它地方,但是此時A沒有id,class,只有一些看似沒用的x,y,w,h,注意:這裡一定要注意這裡的這四個值,因為當我們剛開始呼叫action.dragAndDropBy(k2, -570, 100).perform();時,此時拖動完之後,那麼絕對此時的x或者y或者w或者h一定是唯一值,那麼我們抓住這個要點就可以定位了
2.定位參考:
WebElement A=driver.findElement(By.xpath("//*[contains(@x,'50')]"));
//"任務跨1"節點
WebElement B=driver.findElement(By.xpath("//*[contains(@y,'150')]"));

總結:

1.注意拖動之後屬性的唯一性
2.dragAndDrop