无法从弹出窗口中选择类似下拉框的值

时间:2013-11-12 05:37:15

标签: java html css xpath selenium

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

面临问题:

无法识别对象,也无法从字段中选择值。

我已经尝试过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>

1 个答案:

答案 0 :(得分:0)

在选择器中使用class属性的正确方法是,前面应加“。”

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

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

你也可以试试这个选择器, id 属性应该是,前面加上“#”

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

refer this to learn more about selectors

编辑: 根据您的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();