css基础篇(六)——选择器优先级计算

1.css选择器计算方法

场景描述:如下代码,你认为文字会显示什么颜色,原因是什么?

<style>
#box .item{
    color:blue;
}
.lbox .list .item{
    color:red;
}
</style>
<div id="box" class="lbox">
    <ul class="list">
        <li class="item">1.其实我是一个演员</li>
        <li class="item">2.其实我是一个演员</li>
    </ul>
</div>

解决上面的问题,先说说怎么计算优先级:

(1)定义几个值:(默认为0)
ICE:表示计算结果;
I    :表示ID选择器;
C   :表示Class选择器;
E   :表示Element(元素)选择器;
(2)计算规则:
css表达式遇到Id选择器,则ICE的值+100
css表达式遇到Class选择器,则ICE的值+10
css表达式遇到Element选择器,则ICE的值+1
(3)结果说明:
ICE的结果越大说明该选择器表达是的优先级越高

说明:!important优先级最高(一旦定义了!important,该表达式的优先级就是最高的);  *选择器最低

如下图:举个例子

回到上面要解决的问题:

#box .item 表达式根据上面的计算方法:ICE=110;

.lbox .list .item表达式计算结果:ICE=30;

所以最终的上面代码文字显示颜色为blue;

posted @ 2015-12-27 19:31  web-bk  阅读(268)  评论(0编辑  收藏  举报