2017-03-16 52 views
1

我正在为以下代码编写selenium脚本。动态查找使用硒xpath的以前的同级元素

<div id="abc" class="ui-selectmanycheckbox ui-widget hpsapf-chechkbox"> 
    <div class="ui-chkbox ui-widget"> 
     <div class="ui-helper-hidden-accessible"> 
      <input id="abc:0" name="abc" type="checkbox" value="0" checked="checked"> 
     </div> 
     <div class="ui-chkbox-box ui-widget ui-corner-all ui-state-default ui-state-active"> 
      <span class="ui-chkbox-icon ui-icon ui-icon-check ui-c"></span> 
     </div> 
    </div> 
    <span class="hpsapf-radio-label"> 
     <label for="abc:0">Herr</label> 
    </span> 
    <div class="ui-chkbox ui-widget"> 
     <div class="ui-helper-hidden-accessible"> 
      <input id="abc:1" name="abc" type="checkbox" value="1"> 
     </div> 
     <div class="ui-chkbox-box ui-widget ui-corner-all ui-state-default"> 
      <span class="ui-chkbox-icon ui-icon ui-icon-blank ui-c"></span> 
     </div> 
    </div> 
    <span class="hpsapf-radio-label"> 
     <label for="abc:1">Frau</label> 
    </span> 
</div> 

这些复选框如下所示。复选框的数量根据数据库值进行更改。

enter image description here

在我的代码我首先检查了“已婚的女性”复选框是否被选中与否。所以我试着下面的代码片段。

WebElement mainElement= driver.findElement(By.id("abc")); 
WebElement label=mainElement.findElement(By.xpath(".//label[contains(@for,'abc')][text() = 'Frau']")); 
WebElement parent = label.findElement(By.xpath("..")); 
WebElement div = parent.findElement(By.xpath("preceding-sibling::::div")); 
WebElement checkBox = div.findElement(By.className("ui-chkbox-box")); 
String css = checkBox.getAttribute("class"); 
if(css.contains("ui-state-active")) { 
    return "checked"; 
} 
else 
{ 
    return "unchecked"; 
} 

但是,当我试图执行此脚本。 WebElement div = parent.findElement(By.xpath("preceding-sibling::::div"));给了我第一个div标签,而不是前一个。我想要一个兄弟姐妹。

回答

2

使用::和索引,不::::

WebElement div = parent.findElement(By.xpath("preceding-sibling::div[1]")); 
+0

但如果我有3个的复选框,并要检查3吗?这是否工作 –

+0

@CharveeShah'div [1]'中的索引将引导你到你想要的元素。 – Guy