<li class="navbar-nav-item ">
<a href="#" id="cust">XX管理</a>
<ul class="navbar-dropdown-menu">
<li class="dropitem-current"><a href="/Customer/Index">XX列表</a></li>
<li class="navbar-dropitem" id="list_2"><a href="/Customer/CommunicateIndex">XX列表</a></li>
</ul>
</li>
第一種:
先將鼠標移動至須要通過懸停的元素,再獲取顯示的元素並點擊;代碼示例以下:
Actions action = new Actions(chrome);
action.moveToElement(chrome.findElement(By.id("cust") )).perform(); // 鼠標移動到 toElement 元素中點
Thread.sleep(1000);
chrome.findElement(By.id("list_2") ).click(); // 【XX列表】click事件
chrome.manage().window().maximize(); // 窗口最大化
action.release(); // 鼠標事件釋放
PS:
- 建議通過懸停的時候加入等待;
- 因鼠標事件穩定性較差建議操做後將窗口最大化;
- 鼠標事件結束後建議釋放;
第二種:
對於菜單中的隱藏的下拉選項,鼠標懸浮時才顯示出來,調用 action.moveToElement(element).build().perform();或 action.keyDown(keys).build().perform();通常狀況下都是能夠解決的。然而某些時候卻無論用,這時能夠藉助JavaScript實現隱藏元素的點擊操做,代碼示例以下:
JavascriptExecutor js = (JavascriptExecutor) chrome;
myjs="document.getElementsByClassName('dropitem-current')[0].childNodes[0].click();";
System.out.print(myjs);
js.executeScript(myjs);