详解CSS选择器、优先级与匹配原理

最常用的五类CSS选择器

准确而简洁的运用CSS选择器会达到非常好的效果。我们不必通篇给每一个元素定义类(class)或ID,通过合适的组织,可以用最简单的方法实现同样的效果。在实际工作中,最常用的选择器有以下五类:

一、标签选择器:

顾名思议,标签选择器是直接将HTML标签作为CSS选择器,可以是p、h1、dl、strong等HTML标签。如:

p{font:12px;}  
em{color:blue;}  

dl{float:left;margin-top:10px;}  

 

二、id选择器:

我们通常给页面元素定义id。例如定义一个层<divid="menubar"></div>然后在样式表里这样定义:

  1. #menubar{  
    margin:0auto;  
    background:#ccc;  
    color:#c00;  
    }  
     

其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
id选择器也同样支持后代选择器,例如:#menubarp{text-align:center;line-height:20px;;}这个方法主要用来定义层和那些比较复杂,有多个“唯一后代”的元素。

三、类(class)选择器:

在CSS里用一个点开头表示类别选择器定义,例如:

  1. .da1{  
    color:#f60;  
    font-size:14px;  
    }  

在页面中,用class="类别名"的方法调用:<spanclass="da1">14px大小的字体</span>这个方法比较简单灵活,可以随时根据页面需要新建和删除。但需要避免多class综合症。

四、群组选择器:

当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,这就是CSS选择器中的群组选择器。如:

  1. p,td,li{  
    line-height:20px;  
    color:#c00;  
    }  
    #mainp,#siderspan{  
    color:#000;  
    line-height:26px;  
    }  
    .www_52css_com,#mainpspan{  
    color:#f60;  
    }  
    .text1h1,#siderh3,.art_titleh2{  
    font-weight:100;  
    }  

使用组群选择器,将会大大的减化CSS代码,将具有多个相同属性的元素,合并群组进行选择,定义同样的CSS属性,这大大的提高了编码效率与CSS文件体积。

五、后代选择器:

CSS选择器中的后代选择器也叫派生选择器。可以使用后代选择器给一个元素里的子元素定义样式,例如这样:

  1. listrong{  
    font-style:italic;  
    font-weight:800;  
    color:#f00;  
    }  
    #mainp{  
    color:#000;  
    line-height:26px;  
    }  
    #sider.conspan{  
    color:#000;  
    line-height:26px;  
    }  
    .www_52css_compspan{  
    color:#f60;  
    }  
    #siderulli.subnav1{  
    margin-top:5px;  
    }  

     

第一段,就是给li下面的子元素strong定义一个斜体加粗而且套红的样式。其他以此类推。
后代选择器的使用是非常有益的,如果父元素内包括的HTML元素具有唯一性,则不必给内部元素再指定class或id,直接应用此选择器即可,例如下面的h3与ul就不必指定class或id。

  1. <divid="sider"> 
    <h3></h3> 
    <ul> 
    <li>...</li> 
    <li>...</li> 
    <li>...</li> 
    </ul> 
    </div> 
     

     

在这里CSS就可以及样写:

  1. #siderh3{...}  
    #siderul{...}  
    #siderulli{...} 

结合使用上面的四种CSS选择器,基本满足了CSS布局的需要,主要在于灵活的使用,特别是后代选择器的使用能大大的简化HTML文档,使HTML做到结构化明确,最小的代码实现同样的效果。

 

 优先级与匹配原理

给一个p标签增加一个类(class),可是执行后该class中的有些属性并没有起作用。通过Firebug查看,发现没有起作用的属性被覆盖了。这个时候突然意识到了CSS选择器的优先级问题,这里就CSS选择器的优先级问题做了一些总结。

选择器种类

严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=""的方式,应该是CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。而一般人们将上面这几种方式结合在一起,所以就有了5种或6种选择器了。

三种基本的选择器类型

语法如下:

◆标签名选择器,如:p{},即直接使用HTML标签作为选择器。

◆类选择器,如.polaris{}。

◆ID选择器,如#polaris{}。

注意,ID选择器跟类选择器有很大的不同:一个页面内不能出现相同的ID;再就是ID也是后台开发人员会经常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合十分娴熟之后,这些都不会成为限制。

扩展选择器

◆后代选择器,如.polaris span img{},后代选贼器实际上是使用多个选择器加上中间的空格来找到具体的要控制标签。

◆群组选择器,如div,span,img{},群组选择器实际上是对CSS的一种简化写法,只不过把有相同定义的不同选择器放在一起,省了很多代码。

选择器的优先级别

了解了各种选择器后,还有一个重要的知识点就是CSS选择器的优先级。这也就是为什么polaris会遇到文章开头的问题。举个简单的例子:

  1. <div class="polaris"> 
    <span class="beijixing"> 
    beijixing  
    </span> 
    <span> 
    polaris  
    </span> 
    </div> 

     

如果已经把.polaris下面span内的字体设置成红色:

  1. .polaris span {color:red;} 

这时,如果要改变.beijixing的颜色为蓝色,用下面的命令是不能实现的:

  1. .beijixing {color:blue;} 

出现这种情况就是因为后一个命令的优先级不够,两条相互冲突的样式设置,浏览器只会执行优先级较高的那个。

那么选择器的优先级是怎么规定的呢?

一般而言,选择器越特殊,它的优先级越高。也就是选择器指向的越准确,它的优先级就越高。通常我们用1表示标签名选择器的优先级,用10表示类选择器的优先级,用100标示ID选择器的优先级。比如上例当中 .polaris span {color:red;}的选择器优先级是 10 + 1 也就是11;而 .polaris 的优先级是10;浏览器自然会显示红色的字。理解了这个道理之后下面的优先级计算自是易如反掌:

  1. div.test1 .span var 优先级 1+10 +10 +1  
    span#xxx .songs li 优先级1+100 + 10 + 1  
    #xxx li 优先级 100 +1 

对于什么情况下使用什么选择器,用不同选择器的原则是:第一:准确的选到要控制的标签;第二:使用最合理优先级的选择器;第三:HTML和CSS代码尽量简洁美观。通常:

1、最常用的选择器是类选择器。

2、li、td、dd等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器 .xx li/td/dd {} 的方式选择。

3、极少的情况下会用ID选择器,当然很多前端开发人员喜欢header,footer,banner,conntent设置成ID选择器的,因为相同的样式在一个页面里不可能有第二次。

在这里不得不提使用在标签内引入CSS的方式来写CSS,即:

  1. <div style="color:red">polaris</div> 

这时候的优先级是最高的。我们给它的优先级是1000,这种写法不推荐使用,特别是对新手来说。这也完全违背了内容和显示分离的思想。DIV+CSS的优点也不能再有任何体现。

后代选择器的定位原则

在这里介绍一下对于后代选择器,浏览器是如何查找元素的呢?

浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如DIV#divBox p span.red{color:red;},浏览器的查找顺序如下:先查找html中所有class=‘red‘的span元素,找到后,再查找其父辈元素中是否有p元素,再判断p的父元素中是否有id为divBox的div元素,如果都存在则匹配上。

浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css:

  1. <style> 
    DIV#divBox p span.red{color:red;}  
    ><style> 
    <body> 
    <div id="divBox"> 
    <p><span>s1</span></p> 
    <p><span>s2</span></p> 
    <p><span>s3</span></p> 
    <p><span class=‘red‘>s4</span></p> 
    </div> 
    </body> 

如果按从左到右查找,哪会先查找到很多不相关的p和span元素。而如果按从左到右的方式进行查找,则首先就查找到<span class=‘red‘>的元素。firefox称这种查找方式为key selector(关键字查询),所谓的关键字就是样式规则中最后(最右边)的规则,上面的key就是span.red。

简洁、高效的CSS

所谓高效的CSS就是让浏览器在查找style匹配的元素的时候尽量进行少的查找,下面列出一些我们常见的写CSS犯一些低效错误:

◆不要在ID选择器前使用标签名

一般写法:DIV#divBox

更好写法:#divBox

解释: 因为ID选择器是唯一的,加上div反而增加不必要的匹配。

◆不要再class选择器前使用标签名

一般写法:span.red

更好写法:.red

解释:同第一条,但如果你定义了多个.red,而且在不同的元素下是样式不一样,则不能去掉,比如你css文件中定义如下:

  1. p.red{color:red;}  
    span.red{color:#ff00ff} 

如果是这样定义的就不要去掉,去掉后就会混淆,不过建议最好不要这样写

◆尽量少使用层级关系

一般写法:#divBox p .red{color:red;}

更好写法:.red{..}

◆使用class代替层级关系

一般写法:#divBox ul li a{display:block;}

更好写法:.block{display:block;}

 ID选择器的使用技巧

id用于标识页面唯一元素,id的名称是控制某一内容块的手段,通过将某内容块置入div并赋予唯一的id,就可以用CSS选择器来精确定义每一个页面元素的外观表现,包括标题、列表、图片、链接或者段落等等。例如你为#header写一个CSS规则,就可以完全不同于#content里的图片规则。

可以通过不同规则来定义不同内容块里的链接样式。类似这样:#nav a:link或者 #main a:link或者#footer a:link。也可以定义不同内容块中相同元素的样式不一样。例如,通过#main p和#sider p分别定义#main p和#sider p的样式。从结构上讲,你的页面是由图片、链接、列表、段落等组成的,这些元素本身并不会对显示在什么网络 设备中(PDA还是手机或者网络电视)有影响,它们可以被定义为任何的表现外观。

一个仔细结构化的HTML页面非常简单,每一个元素都被用于结构目的。当你想缩进一个段落,不需要使用blockquote标签,只要使用p标签,并对p 加一个CSS的text-indent规则就可以实现缩进目的。p是结构化标签,text-indent是表现属性,前者属于HTML,后者属于CSS。(这就是传说中的结构与表现相分离)

良好结构的HTML页面内几乎没有表现属性的标签。代码非常干净简洁。例如,原先的代码,现在可以只在HTML中写,所有控制表现的东西都写到CSS中去,在结构化的HTML中, table就是表格,而不是其他什么(更不能被用来布局和定位)。

当然,CSS选择器不只是这么简单,除了id还有class还有后代选择器,属性选择器等等。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。