首页 > 解决方案 > 我需要在下拉框内滚动

问题描述

在 Selenium 中,我正在自动化,但在那个下拉菜单中,我需要单击隐藏的元素。
它向下滚动整个页面我只想向下滚动特定的下拉列表而不是页面。

完整 div 的 HTML 代码:

<ul class="dropdown-menu drop_Loc" role="menu" style="display: none;" xpath="1"> <li> 
<a href="carle_place.aspx" target="_self"> 
<span class="icon-fort icon-left" style="font-size: 40px;padding: 0px 8px;"></span> <span class="nav_icon_heading">Carle Place</span> 
</a> 
</li> 
<li> 
<a href="Selling-a-car-cutler-bay.aspx" target="_self"> 
<span class="icon2-cutlerbay icon-left" style="font-size: 24px;padding: 7px 8px;"></span> 
<span class="nav_icon_heading">Cutler Bay</span> 
</a> 
</li> 
<li> 
<a href="Daytona.aspx" target="_self"> 
<span class="icon-daytona icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Daytona</span> 
</a> 
</li> 
<li> 
<a href="Fort_lauderdale.aspx" target="_self"> 
<span class="icon-fort icon-left" style="font-size: 40px;padding: 0 8px"></span> <span class="nav_icon_heading">Fort Lauderdale</span> 
</a> 
</li> 
<li> 
<a href="Sell-my-car-longwood.aspx" target="_self"> 
<span class="icon-orlando icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Longwood</span> 
</a> 
</li> 
<li> 
<a href="Melbourne.aspx" target="_self"> 
<span class="icon-melbourne icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Melbourne</span> 
</a> 
</li> 
<li> 
<a href="miami.aspx" target="_self"> 
<span class="icon-miami icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Miami</span> 
</a> 
</li> 
<li> 
<a href="Orlando.aspx" target="_self"> 
<span class="icon-orlando icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Orlando</span> 
</a> 
</li> 
<li> 
<a href="St_James.aspx" target="_self"> 
<span class="icon-daytona icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">St James</span> 
</a> 
</li> 
<li> 
<a href="Treasure_coast.aspx" target="_self"> 
<span class="icon-treasure_coast icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Stuart</span> 
</a> 
</li> 
<li> 
<a href="Tampa.aspx" target="_self"> 
<span class="icon-treasure_coast icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">Tampa</span> 
</a> 
</li> 
<li> 
<a id="last-child-location" href="West_palm_beach.aspx" target="_self"> 
<span class="icon-palm_beach icon-left" style="font-size: 40px;padding: 0 8px"></span> 
<span class="nav_icon_heading">West Palm Beach</span> 
</a> 
</li> 
</ul>

向下滚动图片

我试过这些代码,

By Stuart = By.xpath("/html[1]/body[1]/div[1]/nav[1]/div[1]/div[2]/ul[1]/li[2]/ul[1]/li[10]/a[1]/span[2]");

JavascriptExecutor je = (JavascriptExecutor) driver;
                WebElement element = driver.findElement(Stuart);
                je.executeScript("arguments[0].scrollIntoView(true);",element);
                Thread.sleep(4000);

上面的代码正在工作,但它也在滚动下拉菜单和网页。

请帮我解决这个问题。

标签: javahtmlseleniumselenium-webdriver

解决方案


您的代码是正确的,我在您的代码中没有发现任何问题,它应该滚动直到该元素可见。

不要使用绝对 xpath,最好始终使用动态 xpath

请尝试以下代码,

browser.executeScript('window.scrollTo(0,0);').then(function () {
    page.saveButton.click();
}) 

推荐阅读