css 如果所有的子元素都有特定的属性,如何选择父元素?[duplicate]

iyfjxgzm  于 2023-01-18  发布在  其他
关注(0)|答案(2)|浏览(164)
    • 此问题在此处已有答案**:

(33个答案)
15小时前关门了。
如何选择section父元素并应用css样式,如果所有p个子元素都有一个特定的属性(style ="display:无")?

<section>
  <div>
    <p style="display: none">P1</p>
    <p style="display: none">P2</p>
  </div>
</section>
euoag5mw

euoag5mw1#

如果你想用javascript

<section id="container">
      <div id="parent">
        <p style="display: none;">P1</p>
        <p style="display: none;">P2</p>
      </div>
    </section>
const parent = document.getElementById("parent");
const container = document.getElementById("container");

let hasNoneDisplay = 0;

parent.childNodes.forEach((node) => {
  node.style?.display === "none" && hasNoneDisplay++;
});

if (hasNoneDisplay === parent.childNodes.length) {
  //do what you want...
}
g6ll5ycj

g6ll5ycj2#

使用:has选择器。请注意,这是一个非常新的CSS功能,因此尚未得到所有主流浏览器(如Firefox)的支持。

section:has(p[style='display: none']) {
  background: red;
  width: 100px;
  height: 100px;
}

要确认所有的子元素都与特定的属性值匹配,最好的方法是使用:not选择器来选择任何其他可能的值,如果其他可能的值是无限的,并且您必须处理每一种情况,那么我认为您将不得不求助于JavaScript。
示例;

section:has(p[style='display: none']):not(:has(p[style='display: inline'])) {
  background: red;
  width: 100px;
  height: 100px;
}

Demo

相关问题