[英]Dropdown cannot be selected in Selenium - Element not visible
I'm attempting to select a dropdown box via Selenium and am being told the following 我正在尝试通过Selenium选择一个下拉框,并被告知以下内容
Element is not currently visible and so may not be interacted with 元素当前不可见,因此可能无法与之交互
After searching around a bit I've tried the following but am still being given the same error: 经过一番搜索后,我尝试了以下操作,但仍然遇到相同的错误:
WebElement inputElement = driver.findElement(By
.id("diningAvailabilityForm-searchTime"));
((JavascriptExecutor) driver).executeScript(
"arguments[0].checked = true;", inputElement);
((JavascriptExecutor) driver).executeScript(
"arguments[0].checked = true;", inputElement);
((JavascriptExecutor) driver)
.executeScript("$(\"#diningAvailabilityForm-searchTime\").show()");
((JavascriptExecutor) driver).executeScript(
"arguments[0].checked = true;", inputElement);
driver.switchTo().activeElement();
new Select(inputElement).selectByVisibleText("Dinner");
However,this results in the same error. 但是,这将导致相同的错误。 When I open the page in the browser I can see the dropdown, I can also click on the dropdown. 在浏览器中打开页面时,我可以看到下拉菜单,也可以单击下拉菜单。 However, like I said - using this bit of code doesn't achieve what I need. 但是,就像我说的那样-使用这段代码无法实现我所需要的。
The input Element returns as the value is correct. 输入的Element返回值正确。 Made sure to check it was correct by throwing in some errors and it failed as expected. 确保通过抛出一些错误来检查它是否正确,并且按预期失败。
EDIT 2: 编辑2:
Here's the HTML 这是HTML
<span class="selectBox medium standardFormElement status-closed" id="searchTime-wrapper" data-plugins="[["pepSelectBox",{"maxSelectionsLength":"20","maxDisplayOptions":"8","displayScrollBar":"1","displaySpecialDropDown":"1","displaySpecialDropDownHeight":"21","checkIconActive":"1","highlightSelected":"1"}]]" data-prependliststyleenhancements="[]" data-appendliststyleenhancements="[]" data-richoptioncontents="[]" data-extraoptionclass="[]" data-richoptgroup="[]" data-a11ytext=" - Opens menu"> <span class="selectBox-nojs" style="display: none;"> <select name="searchTime" id="diningAvailabilityForm-searchTime" class="searchTime inputElement" min="06:30:00" max="22:30:00" allday="00:00:00 23:30:00" data-plugins="[["pepMealTimeOptionModifier"]]"> <option value="80000712" label="Breakfast" selected="selected">Breakfast</option> <option value="80000717" label="Lunch">Lunch</option> <option value="80000714" label="Dinner">Dinner</option> </select> </span> <span class="richSelectArrowIcon uiGlobalSprite"></span> <div class="select-toggle hoverable" aria-haspopup="true" aria-owns="diningAvailabilityForm-searchTime-dropdown-list" aria-describedby="diningAvailabilityForm-searchTime-label" aria-labelledby="diningAvailabilityForm-searchTime-label" role="button" tabindex="0"><span class="select-value" data-activeoptionclass=""><span class="rawOption"><span class="accessibleText hidden">Time required - Opens menu - </span>Dinner</span> </span> </div> <div class="listWrapper"> <span class="scrollbarTrack"></span> <div class="innerListWrapper"> <ol class="dropdown-list" id="diningAvailabilityForm-searchTime-dropdown-list" aria-hidden="true" role="listbox" aria-label="Time&nbsp;required - Opens menu"> <li role="option" data-value="80000712" data-display="breakfast" data-extraoptionclass="" class="selectOption" id="diningAvailabilityForm-searchTime-0" aria-setsize="36" aria-posinset="1"><span class="rawOption"><span class="accessibleText hidden">Time required - Opens menu - </span>Breakfast</span> </li> <li role="option" data-value="80000717" data-display="lunch" data-extraoptionclass="" class="selectOption" id="diningAvailabilityForm-searchTime-1" aria-setsize="36" aria-posinset="2"><span class="rawOption"><span class="accessibleText hidden">Time required - Opens menu - </span>Lunch</span> </li> <li role="option" data-value="80000714" data-display="dinner" data-extraoptionclass="" class="selectOption" id="diningAvailabilityForm-searchTime-2" aria-setsize="36" aria-posinset="3"> </ol> </div> </div> <span class="shadow-mask"></span> </span>
You are probarly trying to use the element before it is visible. 您可能正在尝试使用该元素,然后该元素才可见。
WebDriverWait wait = new WebDriverWait(driver, 30);
wait.until(ExpectedConditions.refreshed(ExpectedConditions.visibilityOfElementLocated(by)));
wait.until(ExpectedConditions.refreshed(ExpectedConditions.elementToBeClickable(by)));
Effective wait methods for your situation 针对您情况的有效等待方法
If it didnt work, you could also try 如果没有用,您也可以尝试
waitUntil(Waits.elementDisplayed(WebElement));
((JavascriptExecutor) driver)
.executeScript("document.getElementsByClassName(\"selectBox-nojs\")[1].style.display = ''");
((JavascriptExecutor) driver)
.executeScript("document.getElementsByClassName(\"selectBox-nojs\")[2].style.display = ''");
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.