我有一个下拉框,我想使用 WebDriverJS 选择一个值。我查看了下面的用户指南,但不知道如何操作
我什至尝试了一些为 Java 版本记录的东西,如下所示:
webdriver.Select(driver.findElement(webdriver.By.id("vote"))).selectByValue("5")
它只是简单地说“选择”不存在。
我浏览了源代码,但仍然找不到任何可以使用的东西。
我有一个下拉框,我想使用 WebDriverJS 选择一个值。我查看了下面的用户指南,但不知道如何操作
我什至尝试了一些为 Java 版本记录的东西,如下所示:
webdriver.Select(driver.findElement(webdriver.By.id("vote"))).selectByValue("5")
它只是简单地说“选择”不存在。
我浏览了源代码,但仍然找不到任何可以使用的东西。
您不需要单击两次来选择一个选项,只需直接单击该选项即可。就像是,
driver.findElement(wd.By.css('#month>option[title="November"]')).click();
我分享了一个功能来通过它的文字在这里选择一个下拉项目。
编码:
function selectOption(selector, item){
var selectList, desiredOption;
selectList = this.findElement(selector);
selectList.click();
selectList.findElements(protractor.By.tagName('option'))
.then(function findMatchingOption(options){
options.some(function(option){
option.getText().then(function doesOptionMatch(text){
if (item === text){
desiredOption = option;
return true;
}
});
});
})
.then(function clickOption(){
if (desiredOption){
desiredOption.click();
}
});
}
与:
driver.selectOption = selectOption.bind(driver);
driver.selectOption(webdriver.By.id('my-dropdown'), 'My Value');
driver.findElement({id: 'myDropDown'});// select dropdown element you wish to select
driver.sleep(1000);//not necessary
driver.findElement({id: 'myDropDown'}).sendKeys('name_of_option');//sending keys automatically fills dropdown with desired option
我正在使用webdriverjs并想按索引选择选项,所以这样做了:
driver.click('#my_select_box').click('#my_select_box option:nth-child(3)')
这应该通过
selectElem = driver.findElement(webdriver.By.id("vote"))
selectElem.click()
selectElem.findElement(webdriver.By.css("option[value='5']")).click()
在这种情况下,将键发送到下拉元素就足够了,例如;
driver.findElement(by.id('vote')).sendKeys('5');
当显示文本中有空格时,webdriver需要更多的关注,添加点击功能就可以解决;
var ddlElement = driver.findElement(by.id('vote'));
ddlElement.click();
ddlElement.sendKeys('5');
ddlElement.click();
某些浏览器很难使用下拉菜单。我得到了一些想法并拼凑了一个使用 JS 注入的 java 方法,这可能对遇到这个问题的一些人有用。是的,随着时间的推移,这些问题正在得到解决,但这对于那些负责认证旧浏览器的人来说很有用。我希望这会有所帮助,因为这可能会非常令人沮丧!
public void getJSDropdown(String dropDown, String elementID)throws Exception{
JavascriptExecutor executor = (JavascriptExecutor)driver;
String dropdownScript = "var select = window.document.getElementById('" +
dropDown +
"'); for(var i = 0; i < select.options.length; i++){if(select.options[i].text == '" +
elementID +
"'){ select.options[i].selected = true; } }";
Thread.sleep(2000);
executor.executeScript(dropdownScript);
Thread.sleep(2000);
String clickScript = "if ("+"\"createEvent\""+" in document) {var evt = document.createEvent("+"\"HTMLEvents\""+"); evt.initEvent("+"\"change\""+", false, true); " + dropDown + ".dispatchEvent(evt); } else " + dropDown + ".fireEvent("+"\"onchange\""+");";
executor.executeScript(clickScript);
}
driver.click('//*[@id="vote"]/option[3]')
我在 ES6 中使用了以下内容:
let select = driver.findElement(By.css("select"));
let options = select.findElements(By.css("option"));
options.then(values => {
return Promise.all(values.map(el => el.getText())).then(optTexts => {
return values[optTexts.indexOf('Some option text')].click();
});
});
我遇到了同样的问题,上面的解决方案在我的 typeScript 案例中不起作用
但我仍然找到了解决方案:
await driver.findElement(By.id("ELEMENT_ID")).sendKeys("SOME_VALUE");
由于驱动程序在获取选择器元素时会返回一个承诺
所以添加等待来做接下来的事情
这对我有用(咖啡脚本)
selectList.findElements(By.tagName("option")) =
.then (options) ->
len = options.length #getting number of options in the select
driver.wait => #verify all promises finished
for option in options
option.getText()
.then (text) =>
console.log(len)
len -= 1
console.log(text)
if len is 0
true
, 10000
像这样使用xpath
await driver.findElement(By.xpath('//[@id="newEventOffices"]/option[3]')).click();
找到选择元素并单击它以显示下拉菜单
driver.findElement(//div//select[@id="elementId"]).click();
然后从选项中选择并单击它。我认为通过 xpath 选择在这里会更好。
driver.findElement(By.xpath('//div//select[@id="elementId"]//option[optionIndex]')).click();
这实际上不是单击该选项,但它确实选择了它。
以下代码定义了 WebDriverJS 中可用的选择器:
webdriver.Locator.Strategy = {
'className': webdriver.Locator.factory_('class name'),
'class name': webdriver.Locator.factory_('class name'),
'css': webdriver.Locator.factory_('css selector'),
'id': webdriver.Locator.factory_('id'),
'js': webdriver.Locator.factory_('js'),
'linkText': webdriver.Locator.factory_('link text'),
'link text': webdriver.Locator.factory_('link text'),
'name': webdriver.Locator.factory_('name'),
'partialLinkText': webdriver.Locator.factory_('partial link text'),
'partial link text': webdriver.Locator.factory_('partial link text'),
'tagName': webdriver.Locator.factory_('tag name'),
'tag name': webdriver.Locator.factory_('tag name'),
'xpath': webdriver.Locator.factory_('xpath')
};
goog.exportSymbol('By', webdriver.Locator.Strategy);
来源:https ://code.google.com/p/selenium/source/browse/javascript/webdriver/locators.js