【问题标题】:Which CSS pseudo-classes don't have specificity?哪些 CSS 伪类没有特异性?
【发布时间】:2020-04-09 06:13:51
【问题描述】:

我正在学习一点 CSS,并且通过阅读,有一些伪类没有特定性,例如 where()not()。还有更多吗?

【问题讨论】:

    标签: css pseudo-class css-specificity


    【解决方案1】:

    如果您检查规范,您可以找到特异性计算的完整细节。我将参考包含所有新选择器的CSS selectors level 4

    对于给定元素,选择器的特异性计算如下:

    • 统计选择器中 ID 选择器的数量 (= A)
    • 统计选择器中的类选择器、属性选择器和伪类的数量 (= B)
    • 计算选择器中类型选择器和伪元素的数量 (= C)
    • 忽略通用选择器

    如果选择器是选择器列表,则为列表中的每个选择器计算此数字。对于针对列表的给定匹配过程,有效的特异性是列表中匹配的最特定选择器的特异性。

    一些伪类为其他选择器提供“评估上下文”,因此专门定义了它们的特殊性:

    :is():not():has() 伪类的特异性被其选择器列表参数中最具体的复杂选择器的特异性替换

    类似地,:nth-child():nth-last-child() 选择器的特异性是伪类本身的特异性(算作一个伪类选择器)加上其选择器列表参数中最具体的复杂选择器的特异性(如果任何)。

    :where() 伪类的特异性被零替换。

    所以基本上,* 永远不会计数,:where() 也是如此。您还可以阅读:

    :where 伪类和它的任何参数都不会影响选择器的特异性——它的特异性总是为零。 ref

    对于:is():not():has(),请考虑里面的内容。这意味着以下选择器具有相同的特异性:

    a:not(.class) == a.class
    a:not(#id):is(.class) == a#id.class
    

    但要注意这句话:被其选择器列表参数中最具体的复杂选择器的特异性所取代。在不久的将来,我们可以写出类似的东西:

    a:not(.class, #id)
    

    其特异性等于

    a#id
    

    而不是

    a.class#id
    

    考虑到这一点,只有:where() 没有任何特异性,或者用更好的词来说,对特异性计算没有贡献。 :not():is():has() 只是基于它们内部的内容,不像 :nth-child() 我们在 B 中计算它,我们也计算它包含的内容。

    请注意,将来我们可以编写如下内容:

     a:nth-child(-n+3 of li.important)
    

    其具体性等于 1 个类选择器 (.important) + 1 个伪类 (:nth-child) + 2 个类型选择器 (a li)

    【讨论】:

    • 我们可以使用:is():has() 吗?我试图使用它们,但它不适合我。
    • @ghost2092000 他们仍然没有支持,你不能使用它们。我考虑了详细说明实际和未来选择器以使答案通用的新规范,但实际上您只有可以使用的 :not() 选择器
    • :host 的特殊性是怎么回事?
    • @Mendy drafts.csswg.org/css-scoping/#host-selector : :host 的特殊性是伪类的特殊性。 :host() 的特殊性是伪类的特殊性,加上其参数的特殊性。
    猜你喜欢
    • 1970-01-01
    • 2014-07-11
    • 2013-03-30
    • 2012-06-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-02-01
    • 1970-01-01
    相关资源
    最近更新 更多