Java Selenium Actions模擬滑鼠拖動dragAndDrop總結
阿新 • • 發佈:2019-02-10
滑鼠拖動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