微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

CSS直接后代(>)在选择性上没有任何价值吗?

给出以下类声明和代码……
.foo > a { color:green; }
.bar a { color:red; }
<div class="bar">
    <div class="foo">
        <a href="#">SOME LINK</a>
    </div>
</div>

…我认为链接是绿色的,因为虽然两个声明都有一个类(010)和一个元素(001),但.foo有直接的后代选择器.但是,唉,这个链接是红色的.为什么?

解决方法

>没有价值对于css特异性.

两种情况都有11个特异性值:

.foo > a { color:green; }/*specificity value is 11*/
.bar a { color:red; }/*specificity value is 11*/

在您的情况下,您可以使用这样的更具体的特点:

.bar .foo > a { color:green; }/*greater specificity value is 21*/
.foo a { color:red; }/*specificity value is 11*/

好的,我要在这里添加特异性如何工作:

Selector                          Specificity         Specificity in large base
inline-style                      1 0 0 0             1000
id selector                       0 1 0 0              100
class,pseudo,attribute selector   0 0 1 0               10
type selector and pseudo elements 0 0 0 1                1

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。