CSS Selector “(A or B) and C”?

前端 未结 4 1204
时光取名叫无心
时光取名叫无心 2020-11-27 14:24

This should be simple, but I\'m having trouble finding the search terms for it.
Let\'s say I have this:

Foo
相关标签:
4条回答
  • 2020-11-27 14:46

    If you have this:

    <div class="a x">Foo</div>
    <div class="b x">Bar</div>
    <div class="c x">Baz</div>
    

    And you only want to select the elements which have .x and (.a or .b), you could write:

    .x:not(.c) { ... }
    

    but that's convenient only when you have three "sub-classes" and you want to select two of them.

    Selecting only one sub-class (for instance .a): .a.x

    Selecting two sub-classes (for instance .a and .b): .x:not(.c)

    Selecting all three sub-classes: .x

    0 讨论(0)
  • 2020-11-27 14:51

    No. Standard CSS does not provide the kind of thing you're looking for.

    However, you might want to look into LESS and SASS.

    These are two projects which aim to extend default CSS syntax by introducing additional features, including variables, nested rules, and other enhancements.

    They allow you to write much more structured CSS code, and either of them will almost certainly solve your particular use case.

    Of course, none of the browsers support their extended syntax (especially since the two projects each have different syntax and features), but what they do is provide a "compiler" which converts your LESS or SASS code into standard CSS, which you can then deploy on your site.

    0 讨论(0)
  • 2020-11-27 14:54

    Not yet, but there is the experimental :matches() pseudo-class function that does just that:

    :matches(.a .b) .c {
      /* stuff goes here */
    }
    

    You can find more info on it here and here. Currently, most browsers support its initial version :any(), which works the same way, but will be replaced by :matches(). We just have to wait a little more before using this everywhere (I surely will).

    0 讨论(0)
  • 2020-11-27 14:56

    is there a better syntax?

    No. CSS' or operator (,) does not permit groupings. It's essentially the lowest-precedence logical operator in selectors, so you must use .a.c,.b.c.

    0 讨论(0)
提交回复
热议问题