我在nodeJS上运行WebdriverJS来测试网站的UI。我想选择并单击下拉菜单栏中的子菜单项。子菜单项由CSS隐藏。菜单栏看起来像这样:
<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)
有什么想法吗?
答案 0 :(得分:0)
这对我来说也是新手,但我会链接点击下拉列表的函数调用,然后单击所需的下拉项。
答案 1 :(得分:0)
试试这个:
var menu = mydriver.findElement(mywebdriver.By.css('[href="/MyProducts"]'));
menu.click();
menu.findElement(mywebdriver.By.css('[href="/jkjkjk"]')).click();
詹姆斯说它是关于链接的。在上面的代码段中,链接是隐式的(findElement和click方法都会向webdriver.controlFlow()添加一个框架。