新闻资讯
记录首创点滴进步 见证远行
我们一直紧跟时代前沿,聚焦行业实时动态,发布公司最新资讯,欢迎您的关注

8.26日音讯,网页制作之选择器优先级的实际运用

日期:2013-08-26发布:首创网络浏览:614次

    8.26日音讯,网页制作之选择器优先级的实际运用。严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=的方式,应该是CSS的一种引入方式···

    本文关键字:8.26日,音讯,网页制作,之,选择器,优先级,的,

  

   8.26日音讯,网页制作之选择器优先级的实际运用。严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=""的方式,应该是CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。

 

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

  选择器种类

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

  三种基本的选择器类型

  语法如下:

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

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

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

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

  扩展选择器

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

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

  选择器的优先级别

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

  beijixingpolaris

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

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

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

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

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

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

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

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

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

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

  polaris

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

  后代选择器的定位原则

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

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

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