【问题标题】:CSS select nested elements up to N levels deepCSS 选择最多 N 层的嵌套元素
【发布时间】:2016-11-30 11:35:32
【问题描述】:

我有许多嵌套元素,我试图只选择前 N 个级别。下面显示了一个工作示例,其中我选择了前 7 个级别并设置它们的样式。这正是我想要的方式,但是,我希望有一种选择这些元素的简化方法。

在我的实际用例中,我不知道嵌套元素的总数,并且我试图选择前50个级别,所以使用上述方法会很混乱。不幸的是,我无法在我的应用程序中更改 HTML,因此它必须是纯 CSS 方法。谢谢。

.container > div,
.container > div > div,
.container > div > div > div,
.container > div > div > div > div,
.container > div > div > div > div > div,
.container > div > div > div > div > div > div,
.container > div > div > div > div > div > div > div {
  border-left: 1px solid;
  padding-left: 15px;
}
<div class="container">
  <div>
    A
    <div>
      B
      <div>
        C
        <div>
          D
          <div>
            E
            <div>
              F
              <div>
                G
                <div>
                  H
                  <div>
                    I
                  </div>
                </div>
              </div>
            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>

【问题讨论】:

标签: css nested


【解决方案1】:

这在迄今为止的所有 CSS 版本中都是不可能的,据我所知,选择所有元素达到指定级别的 Descendant Level Selector 短期内不会实施。 p>


您可以做的是为您想要选择和使用的所有元素设置一个类:

.container .class {
    border-left: 1px solid;
    padding-left: 15px;  
 }

如果您无法对 HTML 进行任何更改或使用 JavaScript,那么您目前拥有的就是您最好的选择。

【讨论】:

    猜你喜欢
    • 2014-01-20
    • 1970-01-01
    • 1970-01-01
    • 2011-03-28
    • 1970-01-01
    • 2015-10-31
    • 2016-10-17
    • 2021-12-28
    • 1970-01-01
    相关资源
    最近更新 更多