当前位置: 网站建设 > 网页设计 > 建站经验 >

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

时间:2013-03-02 04:15来源:未知 作者:admin 点击:

标签:详解CSS选择器、优先级与匹配原理 原理(10)来讲(3)优先级(7)匹配(6)CSS(823)选择器(20)严厉(1)详解(47)
严厉来讲,选择器的品种能够分为三种:标签名挑选器、类选择器和ID选择器。而所谓的后辈抉择器和群组选择器只不外是对前三种选择器的扩大利用。而在标签内写入style=的方法,应当是CSS的一种引入方式,而不是选择器,由于基本就不用到选择器。而个别人们将上面这多少种方式联合在一起,所以就有了5种或6种取舍器了。 浏览器从右到左进行查找的利益是为了尽早过滤掉一些无关的样式规则和元素。比如如下html和css: 说明: 因为ID选择器是独一的,加上div反而增添不用要的匹配。 --> [网站建设之]详解CSS选择器
详解CSS选择器、优先级与匹配原理》文章地址:http://www.tfxk.com/wangyesheji/jianzhanjingyan/030234Z02013.htm

严厉来讲,选择器的品种能够分为三种:标签名挑选器、类选择器和ID选择器。而所谓的后辈抉择器和群组选择器只不外是对前三种选择器的扩大利用。而在标签内写入style=""的方法,应当是CSS的一种引入方式,而不是选择器,由于基本就不用到选择器。而个别人们将上面这多少种方式联合在一起,所以就有了5种或6种取舍器了。

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

说明: 因为ID选择器是独一的,加上div反而增添不用要的匹配。

--> [网站建设之]详解CSS选择器、优先级与匹配原理

文章就CSS选择器的优先级问题做了一些总结,严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。

      作为一个Web开发者,控制必要的前台技巧也是很重要的,特别是在遇到一些实际问题的时候。这里给大家列举一个例子:

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

.beijixing {color:blue;} 

出现这种情况就是因为后一个命令的优先级不够,两条彼此抵触的样式设置,浏览器只会履行优先级较高的那个。

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

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

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

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

假如是这样定义的就不要去掉,去掉后就会混杂,不过倡议最好不要这样写

Tag:CSS   选择器   CSS   选择器  

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

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

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

正常写法:#divBox p .red{color:red;}

◆使用class取代层级关系

一般写法:span.red

一般写法:DIV#divBox

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

<,详解CSS背景Background属性;div class="polaris"> <span class="beijixing"> beijixing  </span> <span> polaris  </span> </div> 

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

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

.polaris span {color:red;} 

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

选择器的优先级别

昆裔选择器的定位准则

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

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

这时候的优先级是最高的。咱们给它的优先级是1000,这种写法不推举应用,特殊是对新手来说。这也完整违反了内容跟显示分别的思维。DIV+CSS的长处也不能再有任何体现。

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

更好写法:.red

<style> DIV#divBox p span.red{color:red;}  ><style> ,详解CSS网页设计中字体大小(em)的问题;<body> <div id="divBox"> <p><span>s1</span></p> <p><span>s2</span></p> <p><span>s3</span></p> <p>,详解CSS网页布局中默认字体样式;<span class='red'>s4</span></p> </div> </body> 

如果按从左到右查找,哪会先查找到良多不相干的p和span元素。而如果按从左到右的方式进行查找,则首先就查找到<span class='red'>的元素。firefox称这种查找方式为key selector(症结字查问),所谓的要害字就是款式规矩中最后(最右边)的规则,上面的key就是span.red。

懂得了各种选择器后,还有一个主要的常识点就是CSS选择器的优先级。这也就是为什么polaris会碰到文章开头的问题。举个简略的例子:

简练、高效的CSS

◆尽量少使用层级关联

更好写法:.red{..}

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

◆后世选择器,如.polaris span img{},后代选贼器实际上是使用多个选择器加上旁边的空格来找到详细的要把持标签。

三种基础的选择器类型

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

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

语法如下:

普通而言,选择器越特别,它的优先级越高。也就是选择器指向的越正确,它的优先级就越高。通常我们用1表现标签名选择器的优先级,用10表示类选择器的优先级,用100标示ID选择器的优先级。比方上例当中 .polaris span {color:red;}的选择器优先级是 10 + 1 也就是11;而 .polaris 的优先级是10;浏览器天然会显示红色的字。懂得了这个情理之后下面的优先级盘算自是轻而易举:

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

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

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

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

留神,详解CSS盒子模型,ID选择器跟类选择器有很大的不同:一个页面内不能呈现雷同的ID;再就是ID也是后盾开发职员会常常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合非常娴熟之后,这些都不会成为限度。

选择器种类

浏览器CSS匹配不是从左到右进行查找,而是从右到左进行查找,详解CSS的背景属性的设置方法。好比DIV#divBox p span.red{color:red;},浏览器的查找次序如下:先查找html中所有class='red'的span元素,找到后,再查找其父辈元素中是否有p元素,再断定p的父元素中是否有id为divBox的div元素,如果都存在则匹配上。

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

更好写法:#divBox

扩展选择器


(责任编辑:网站建设)
详解CSS选择器、优先级与匹配原理相关文章
上一篇:详解CSS背景Background属性 下一篇:详解CSS阴影的使用
回到顶部