我正在尝试为我的WebApp选择菜单选项,能够单击菜单,菜单选项也可见但无法单击菜单选项。
如果我尝试检查菜单选项的可见性,请使用Selenium API,它表示不可见,但实际上它已在屏幕上显示。
是否有使用Selenium IE Driver选择菜单和菜单选项的标准。
以下是菜单/菜单选项代码:
<DIV style="BORDER-BOTTOM: 2px outset; POSITION: absolute; BORDER-LEFT: 2px outset; WIDTH: 162px; FONT-FAMILY: Tahoma; BACKGROUND: #e4e4e4; HEIGHT: 106px; FONT-SIZE: 8pt; BORDER-TOP: 2px outset; TOP: 0px; BORDER-RIGHT: 2px outset; LEFT: 0px">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(0,'smConfig0')"><SPAN>Config. Management</SPAN> </DIV><INPUT id=lgx_smConfig01 type=hidden SP="" LP="<LinkParams lgx_ID='WideDetail' FromDate='@Data.DefaultDate.FromDate~' ToDate='@Data.DefaultDate.ToDate~' lgx_DetailID='dtlConfig' FirstTime='1' ConfigType='2' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(1,'smConfig1')"><SPAN>Custom Configuration</SPAN> </DIV><INPUT id=lgx_smConfig11 type=hidden SP="" LP="<LinkParams lgx_ID='Default' lgx_ListID='lstCustomConfig' ConfigType='1' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(2,'smConfig2')"><SPAN>Custom Transition</SPAN> </DIV><INPUT id=lgx_smConfig21 type=hidden SP="" LP="<LinkParams lgx_ID='Default' lgx_ListID='lstCustomTransition' Flag='512' Title='Custom' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(3,'smConfig3')"><SPAN>Person Hierarchy Level</SPAN> </DIV><INPUT id=lgx_smConfig31 type=hidden SP="" LP="<LinkParams lgx_ID='Default' lgx_ListID='lstPersonLevel' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(4,'smConfig4')"><SPAN>Role</SPAN> </DIV><INPUT id=lgx_smConfig41 type=hidden SP="" LP="<LinkParams lgx_ID='Default' lgx_ListID='lstRoleConfig' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx">
<DIV style="PADDING-BOTTOM: 2px; PADDING-LEFT: 15px; PADDING-RIGHT: 2px; HEIGHT: 17px; COLOR: black; CURSOR: hand; PADDING-TOP: 2px" onmouseover="this.style.background='darkblue';this.style.color='white';" onmouseout="this.style.background=this.runtimeStyle.background;this.style.color='black';" onclick="parent.smConfig_Click(5,'smConfig5')"><SPAN>Status</SPAN> </DIV><INPUT id=lgx_smConfig51 type=hidden SP="" LP="<LinkParams lgx_ID='Default' lgx_ListID='lstStatusTy' />" Modal="" Features="" Target="_top" Action="lgx_Frame.aspx"> </DIV></DIV>
在上面的菜单选项代码中,我需要点击角色选项。 点击配置菜单即可看到此选项,但点击任何此类菜单选项都没有发生,它也没有抛出任何异常。
请告诉我您的意见或建议以解决此问题。
感谢。
尝试过代码1:
WebElement configMenu = driver.findElement(By.id("mConfigLabel"));
configMenu.click();
WebElement menuOption = driver.findElement(By.xpath("//div[@id='oMenuCntxtsmConfig']/div/div[4]"));
menuOption.click();
尝试过代码2:
WebElement configMenu = driver.findElement(By.id("mConfigLabel"));
configMenu.click();
WebElement menuOption = driver.findElement(By.xpath("//div/descendant:span[contains(text(),'Role']"));
menuOption.click();
尝试过代码3:
configMenu.click();
Actions builder = new Actions(driver);
WebElement roleMenuOption = driver.findElement(By.xpath("//div[@id='oMenuCntxtsmConfig']/div/div[4]"));
builder.moveToElement(configMenu).click(roleMenuOption).build().perform();
尝试过代码4:
WebElement configMenu = driver.findElement(By.id("mConfigLabel"));
configMenu.click();
WebElement roleMenuOption = driver.findElement(By.xpath("//div[@id='oMenuCntxtsmConfig']/div/div[4]"));
((JavascriptExecutor) driver).executeScript("arguments[0].click();", roleMenuOption);
答案 0 :(得分:0)
根据我对你的问题的理解,你只需点击该部门。
您的HTML代码表示onclick事件与div相关联。 这个onClick事件可能会使您的输入(最初隐藏)可见。
现在您还需要点击此输入。
例如,单击“角色”选项,您需要附加此行
driver.findElementByID("lgx_smConfig41").click();
希望这可以帮助你。
答案 1 :(得分:0)
使用selenium播放Dropdown /菜单很棘手,因为下拉/菜单项是隐藏的,直到用户点击Dropdown / Menu才会显示。
你的方法是对的,有点不对..
正确 您访问下拉菜单的方式
错误 您访问“下拉菜单”菜单中的“项目”的方式,因为它们无法直接在“菜单/下拉列表”中隐藏。
请参阅以下代码以正确访问特定菜单项
WebElement DropdownList = driver.findElement(By.id("mConfigLabel"));
Select clickThis = new Select(DropdownList);
clickThis.selectByValue("Role");
我假设你的男人的身份证/ Dropdown是“mConfigLabel”
在stackover流程中有不同的代码风格用于访问菜单项...请看看。
希望这有助于......一切顺利:)