给出以下类声明和代码……
.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