我在nodeJS上运行WebdriverJS来测试网站的UI。我想选择并点击下拉菜单栏中的子菜单项。子菜单项被CSS隐藏。菜单栏是这样的:WebdriverJS和下拉菜单
<ul class="dropdown" id="mainNavList">
<li class="active">
<a href="/home"><span>Home</span></a>
</li>
<li class="">
<a href="/MyProducts"><span>My Products</span></a>
<ul style="visibility: hidden;">
<li class="">
<a href="/uiuiu">Product A</a>
</li>
<li class="">
<a href="/jkjkjk">Product B</a>
</li>
</ul>
</li>
<li>...</li>
</ul>
如果我尝试运行此方法:
mydriver.executeScript("return $(\"a:contains('My Products')\").mouseover();").then(function(){
mydriver.findElement(mywebdriver.By.xpath("//a[contains(text(), 'Product B')]")).click();
});
下拉向下滑动,但它展示后直接隐藏。在控制台我得到一个错误的webdriver的:
ElementNotVisibleError: Element must be displayed to click (WARNING: The server did not provide any stacktrace information)
任何想法?
您需要查找子菜单选项可见的事件。替代鼠标悬停,您可以尝试鼠标移动或点击那个元素。 – Omkar 2013-05-14 02:46:18