0

我必须选择类似于下拉框但不是实际下拉框的字段。选择字段在包含值和子值的弹出窗口中显示值,我需要选择值。

面临的问题:

无法识别对象并且无法从字段中选择值。

我尝试让 cssSelector 识别对象:“ div[class='mailval'][title='Breast > Both'] ”。它不工作。

以下是 HTML 代码:

<div class="rowDiv ">
   <label for="bodypart">Body Part</label>
   <div id="bodypart_box_1">
       <div style="position:absolute;left:185px;z-index: 20">
           <ul class="parent">
               <li>
                   <div id="main" class="mailval">events=Object { click=[1]}handle=function()
                       <input id="bodypart_1" class="bodypart" type="text" onfocus="if($(this).hasClass('disabled')){$(this).blur();}" readonly="readonly" value="Select One" name="bodypart_1" title="">
                       <input id="actualBodypart_1" type="hidden" value="Breast" name="actualBodypart_1">
                   </div>
                   <ul id="bodyPartList_1" class="top sub bodyPartList" style="display: none;">olddisplay="block"
                       <li>
                           <div class="mailval fly" title="Breast" originaltitle="Breast">Breast</div>events=Object { click=[1], mouseover=[1]}handle=function()
                           <ul>
                               <li>
                                   <div class="mailval" title="Breast > Both" originaltitle="Breast > NULL > Both">Both</div>events=Object { click=[1], mouseover=[1]}handle=function()
                               </li>
                               <li>
                                   <div class="mailval" title="Breast > Left" originaltitle="Breast > NULL > Left">Left</div>events=Object { click=[1], mouseover=[1]}handle=function()
                               </li>
                               <li>
                                   <div class="mailval" title="Breast > Right" originaltitle="Breast > NULL > Right">Right</div>events=Object { click=[1], mouseover=[1]}handle=function()
                               </li>
                           </ul>
                       </li>
                   </ul>
               </li>
           </ul>
           <div style="clear:both"></div>
       </div>
       <p id="bodypart-error" class="errorMessage ml161px pa ie7ErrorFix" style="top:140px !important"></p>
   </div>
4

1 回答 1

0

在选择器中使用类属性的正确方法是,它应该以“.”开头。

您的选择器可以重写如下,

div[title='Breast > Both'].mailval

你也可以试试这个选择器,id属性应该以“#”开头

#bodyPartList_1 > div div[title='Breast > Both'].mailval

参考这里以了解有关选择器的更多信息

编辑: 根据您的 html,弹出窗口仅在悬停或单击时出现。可以使用执行此操作JavascriptExecuter

((JavascriptExecutor)driver).executeScript("$('#bodyPartList_1 > .mailval.fly').click();");

现在将显示弹出窗口,您只需选择所需的值...

new WebDriverWait(driver,20).until(ExpectedConditions.visibilityOfElementLocated(By.cssSelector("div[title='Breast > Both'].mailval"))).click();
于 2013-11-12T06:34:34.703 回答