当选项位于单独的标记中时,从选项中选择下拉列表

时间:2013-01-20 10:52:07

标签: drop-down-menu webdriver selenium-webdriver

我是使用webdriver的初学者,这是我正在使用的代码。 我想点击一个下拉列表,然后再次单击为该下拉列表提供的值列表。 请帮助我,我寻找其他线程,但他们是不同的。

<ul>
  <li class="size select required">
    <div id="dk_container_partNumber-55414" class="dk_container dk_theme_size dk_focus"
    tabindex="" style="display: block;">
      <a class="dk_toggle" style="width: 162px;">
        <div class="dk_options">
          <ul class="dk_options_inner">
            <li class="dk_option_current">
              <li class="">
                <a data-dk-dropdown-value="605930243">S</a>
              </li>
              <li class="">
                <a data-dk-dropdown-value="605930251">M</a>
              </li>
              <li class="">
                <a data-dk-dropdown-value="605930260">L</a>
              </li>
              <li class="">
                <a data-dk-dropdown-value="605930278">XL</a>
              </li>
              <li class="">
                <a data-dk-dropdown-value="605930286">XXL</a>
              </li>
          </ul>
        </div>
    </div>
    <select id="partNumber-55414" class="size-select" name="partNumber" style="display: none;">
      <option data-property="CAT_SELECTSIZE" selected="selected" value="">Select Size</option>
      <option value="605930243">S</option>
      <option value="605930251">M</option>
      <option value="605930260">L</option>
      <option value="605930278">XL</option>
      <option value="605930286">XXL</option>
    </select>

我希望选择“S”,同样必须在下拉列表中看到。 我可以点击下拉列表,使用以下代码查看选项列表:

driver.findElement(By.xpath("//(more xpath goes here)/ul/li[@class = 'size select required']/div/a/span")).click();

我尝试使用以下代码选择“S”,但徒劳无功:

Select SizeDropdown = new Select(driver.findElement(By.xpath("//(more xpath  here)/ul/li[@class = 'size select required']/select")));
//driver.findElement(By.xpath("(//(more xpath here)/ul/li[@class = 'size select required']/select)/option[2]")).click();
//Below line gets and clicks the first option of Select Size 'S'
//SizeDropdown.getFirstSelectedOption().click();
//SizeDropdown.selectByVisibleText("S");
//SizeDropdown.selectByIndex(1);
//SizeDropdown.selectByValue("S");

我单独尝试了每个命令(在取消注释后),但是没有看到“S”作为下拉列表的标签,就像我选择它一样。

1 个答案:

答案 0 :(得分:0)

您是否尝试过简化xpath?

我使用类似这样的内容从下拉列表中选择一个选项,而不是首先单击以展开它:

Select select = new Select(driver.findElement(By.xpath("//select[@id='partNumber-55414']"));
select.selectByVisibleText("S");