如何选择没有类的元素,不使用:not()?

时间:2016-02-08 23:09:25

标签: selenium css-selectors capybara

当我使用Capybara和Selenium Webdriver进行一些自动化测试时,我遇到了使用:not attribute选择没有类的元素的问题。
这是我们的元素样本'div':

<div class="intro__card__container">
    <div class="ic--card off" id="pic1"><img alt="Image1" src="/images/landing/intro/image1.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic2"><img alt="Image2" src="/images/landing/intro/image2.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic3"><img alt="Image3" src="/images/landing/intro/image3.jpg" class="ic--image"></div>
    <div class="ic--card" id="pic4"><img alt="Image4" src="/images/landing/intro/image4.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic5"><img alt="Image5" src="/images/landing/intro/image5.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic6"><img alt="Image6" src="/images/landing/intro/image6.jpg" class="ic--image"></div>
    <div class="ic--card" id="pic7"><img alt="Image7" src="/images/landing/intro/image7.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic8"><img alt="Image8" src="/images/landing/intro/image8.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic9"><img alt="Image9" src="/images/landing/intro/image9.jpg" class="ic--image"></div>
    <div class="ic--card off" id="pic10"><img alt="Image10" src="/images/landing/intro/image10.jpg" class="ic--image"></div>
</div>

我正在使用这个选择器“.ic - card:not('。off')”来选择没有'off'类的元素。它适用于jQuery,但在Selenium测试中无效。那么如何选择没有'.off'类的元素?

2 个答案:

答案 0 :(得分:3)

好的 - 再看一遍“.ic - card:not('。off')”的.off不是有效的css选择器,因为.off不会被引用为类选择器。使用

find(".ic--card:not(.off)")  

应该可以正常工作

答案 1 :(得分:3)

您可以使用:

  1. 的CSS:

    find("div[class='ic--card']")

  2. 的xpath:

    find("//div[contains(@class,'ic--card') and not(contains(@class,'off'))]")