Select多选框下拉列表

  在做自动化的过程中,我们经常会遇到select标签类型的多选框下拉列表。针对select标签类型,selenium中有封装好的API可以使用,接下来,我们一起看看关于select多选框下拉列表的操作方法吧。

操作方法简介

1、选择下拉列表方法

selectByIndex(index);  		// 根据索引选择
selectByValue(value); 		// 根据value属性选择
selectByVisibleText(text); 	// 根据选项文本值选择
注意:
index是从0开始的
Value是option标签的一个属性值,并不是显示在下拉框中的值
VisibleText是在option标签中间的值,是显示在下拉框的值


2、取消方法

deselectByIndex(index);			// 根据索引取消
deselectByValue(value);			// 根据value属性取消
deselectByVisibleText(Text);		// 根据选项文本值取消
deselectAll();       			// 取消所有选中


3、其他方法

getAllSelectedOptions();	// 获取所有被选中的标签元素对象集合
getFirstSelectedOption();	// 获取第一个被选中的标签元素对象
select.getOptions();		// 获取所有选项的标签元素对象集合
getWrappedElement();		// 获取包裹具体选项的元素对象
isMultiple();			// 判断该元素是否支持多个对下个,根据mutiple属性来判断,返回布尔值

被测HTML对象

测试用的丐版html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
</head>
<body>
    用户名: <input type="text" name=""/></br>
    密  码: <input type="password" name=""/></br>
    爱好: <input type="checkbox" name="">篮球<input type="checkbox" name="">电影</br>
    性别: <input type="radio" name="gender">男<input type="radio" name="gender">女</br>
    头像: <input type="file" name=""></br>
    住址: <select id="select_province" name="select_name" class ="select_province_class">
			<option value="0">安徽省</option>
			<option value="1">江苏省</option>
			<option value="2">广东省</option>
		</select>
		<select id="select_city" name="select_name" class ="select_city_class">
			<option value="0">滁州市</option>
			<option value="1">南京市</option>
			<option value="2">广州市</option>
		</select></br>
    博客: <a href="" target="_blank">点击进入</a></br>
    备注信息: <textarea>社会人</textarea>
    <form>
        <table border="1">
            <tr><td>姓名</td><td>年龄</td><td>分数</td></tr>
            <tr><td>张三</td><td>28</td><td>100</td></tr>
            <tr><td>李四</td><td>29</td><td>100</td></tr>
          	<tr><td>王二</td><td>29</td><td>100</td></tr>
          	<tr><td>麻子</td><td>29</td><td>100</td></tr>
        </table>
        <img src="https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fimg.diydoutu.com%2Fbqb%2F8031.jpg&refer=http%3A%2F%2Fimg.diydoutu.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1652796255&t=863287e1bacb29390dfefc705fa184ce">
    </form>
</body>
</html>

页面展示:

less 编写多层级对象变量_less 编写多层级对象变量


代码操作

1、选择下拉列表

@Test
public void testDemo1() throws InterruptedException {
    WebDriver driver = new ChromeDriver();
    driver.get("E:\\Notes\\Selenium\\select.html");
    driver.manage().window().maximize();
    Thread.sleep(3000);
    WebElement element = driver.findElement(By.id("select_province"));
    Select select = new Select(element);
    // 选择索引值为2,即第三个选项
    select.selectByIndex(2);
    Thread.sleep(5000);
    // 选择value属性值为1的选择
    select.selectByValue("1");
    Thread.sleep(5000);
    // 选择文本值为安徽省的选项
    select.selectByVisibleText("安徽省");
    Thread.sleep(5000);
}


2、取消方法

取消方法针对的select标签是需要有multiple属性的,没有则抛异常。

在上面html中的select标签中增加multiple="multiple"

<select id="select_province" name="select_name" class ="select_province_class" multiple="multiple">

<select id="select_city" name="select_name" class ="select_city_class" multiple="multiple">

@Test
public void testDemo2() throws InterruptedException {
    WebDriver driver = new ChromeDriver();
    driver.get("E:\\Notes\\Selenium\\select_mutiple.html");
    driver.manage().window().maximize();
    Thread.sleep(3000);
    WebElement element = driver.findElement(By.id("select_city"));
    Select select = new Select(element);
    // 索引值为2的选择后取消
    select.selectByIndex(2);
    Thread.sleep(3000);
    select.deselectByIndex(2);
    Thread.sleep(3000);
    // value属性值为1的选择后取消
    select.selectByValue("1");
    Thread.sleep(3000);
    select.deselectByValue("1");
    Thread.sleep(3000);
    // 选择文本值为安徽省的选项,然后取消
    select.selectByVisibleText("滁州市");
    Thread.sleep(3000);
    select.deselectByVisibleText("滁州市");
    // 取消所有
    select.deselectAll();
    Thread.sleep(3000);
}


3、其他方法

@Test
public void testDemo() throws InterruptedException {
    WebDriver driver = new ChromeDriver();
    driver.get("E:\\Notes\\Selenium\\select.html");
    driver.manage().window().maximize();
    Thread.sleep(3000);
    WebElement element = driver.findElement(By.id("select_province"));
    Select select = new Select(element);

    boolean multiple = select.isMultiple();
    System.out.println("multiple is " + multiple);
    System.out.println("================================================");

    WebElement wrappedElement = select.getWrappedElement();
    System.out.println("wrappedElement is " + wrappedElement.getText());
    System.out.println("================================================");

    List<WebElement> options = select.getOptions();
    System.out.println("The size of allSelectedOptions is " + options.size());
    for(int i=0;i<options.size();i++) {
      System.out.println("第"+ i +"次:" + options.get(i).getText());
    }
    System.out.println("================================================");

    WebElement firstSelectedOption = select.getFirstSelectedOption();
    System.out.println("firstSelectedOption is " + firstSelectedOption.getText());
    System.out.println("================================================");

    List<WebElement> allSelectedOptions = select.getAllSelectedOptions();
    System.out.println("The size of allSelectedOptions is " + allSelectedOptions.size());
    for(int i=0;i<allSelectedOptions.size();i++) {
      System.out.println("第"+ i +"次:" + allSelectedOptions.get(i).getText());
    }

    driver.quit();
}

打印结果:

com.intellij.rt.junit.JUnitStarter -ideVersion5 -junit4 com.test.day02.SelectTest,testDemo
Starting ChromeDriver 96.0.4664.45 (76e4c1bb2ab4671b8beba3444e61c0f17584b2fc-refs/branch-heads/4664@{#947}) on port 37534
Only local connections are allowed.
Please see https://chromedriver.chromium.org/security-considerations for suggestions on keeping ChromeDriver safe.
ChromeDriver was started successfully.
[1650212642.945][WARNING]: This version of ChromeDriver has not been tested with Chrome version 97.
四月 18, 2022 12:24:02 上午 org.openqa.selenium.remote.ProtocolHandshake createSession
信息: Detected dialect: W3C
multiple is false
================================================
wrappedElement is    安徽省
   江苏省
   广东省
  
================================================
The size of allSelectedOptions is 3
第0次:安徽省
第1次:江苏省
第2次:广东省
================================================
firstSelectedOption is 安徽省
================================================
The size of allSelectedOptions is 1
第0次:安徽省

Process finished with exit code 0