【问题标题】:How do I use selenium to change the value of a input[type='range']如何使用 selenium 更改输入的值[type='range']
【发布时间】:2013-04-24 17:00:30
【问题描述】:

我有一个在输入端使用 html5 的滑块 例如

<input id="sliderWidget" title="Slide me" type="range" min="1" max="1.6" step="0.3" value="1.3">

我一直在尝试使用 selenium 来更改滑块,但传统的图像滑块控件不适合我......例如

Action dragAndDrop = builder.dragAndDropBy(sliderWidget,0,30).build();
dragAndDrop.perform();

有没有人知道如何执行这种增量范围更改

提前致谢

【问题讨论】:

    标签: java html selenium range selenium-webdriver


    【解决方案1】:

    您可以直接在 JavaScript 中设置值:

    WebElement slider = webDriver.findElement(By.id("sliderWidget"));
    System.out.println(slider.getAttribute("value"));
    
    JavascriptExecutor js = (JavascriptExecutor) webDriver;
    js.executeScript("javascript:document.getElementById(\"sliderWidget\").value=1.5;");
    
    System.out.println(slider.getAttribute("value"));
    

    请注意,sliderWidget 设置为 1.5,但结果为 1.6。这样您就可以测试step=0.3 是否运行良好。

    【讨论】:

    • 这不是一个现实的测试。即使元素不可访问,这也将起作用。更重要的是,它不会触发 &lt;input&gt; 上的更改处理程序。
    【解决方案2】:

    我发现最稳定和跨浏览器的方法是执行二分搜索,将鼠标拖动到滑块拇指上,直到找到位置。

    我的博客中有 Python/webdriver 代码:http://blog.usetrace.com/?p=279

    【讨论】:

    • 这可能是最现实的方法。但这几乎是一个仅链接的答案。如果不点击链接,我当然无法弄清楚这一点。
    【解决方案3】:

    您可以选择元素并使用 send_keys 方法向其发送右/左箭头键(应该增加/减少输入)。 在 Python 中:

    from selenium.webdriver.common.keys import Keys
    ...
    slider = page.find_element_by_id("sliderWidget")
    for i in range(10):
      slider.send_keys(Keys.RIGHT)
    

    这应该将值增加 10。

    【讨论】:

    • 不错的主意 - 但我得到了WebDriverException: Message: unknown error: cannot focus element
    猜你喜欢
    • 1970-01-01
    • 2022-11-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-06-02
    • 1970-01-01
    相关资源
    最近更新 更多