详解css选择器

上传人:mg****85 文档编号:34144750 上传时间:2018-02-21 格式:DOC 页数:4 大小:37.50KB
返回 下载 相关 举报
详解css选择器_第1页
第1页 / 共4页
详解css选择器_第2页
第2页 / 共4页
详解css选择器_第3页
第3页 / 共4页
详解css选择器_第4页
第4页 / 共4页
亲,该文档总共4页,全部预览完了,如果喜欢就下载吧!
资源描述

《详解css选择器》由会员分享,可在线阅读,更多相关《详解css选择器(4页珍藏版)》请在金锄头文库上搜索。

1、详解 CSS选择器、优先级与匹配原理2010-09-16 15:32 polaris1119 JavaEye 我要评论(7) 字号:T | T文章就 CSS选择器的优先级问题做了一些总结,严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和 ID选择器。AD: 2013大数据全球技术峰会低价抢票中作为一个 Web开发者,掌握必要的前台技术也是很重要的,特别是在遇到一些实际问题的时候。这里给大家列举一个例子:给一个 p标签增加一个类(class) ,可是执行后该 class中的有些属性并没有起作用。通过 Firebug查看,发现没有起作用的属性被覆盖了。这个时候突然意识到了 CSS选择器

2、的优先级问题,这里就 CSS选择器的优先级问题做了一些总结。51CTO推荐阅读: 巧妙地使用 CSS选择器选择器种类严格来讲,选择器的种类可以分为三种:标签名选择器、类选择器和 ID选择器。而所谓的后代选择器和群组选择器只不过是对前三种选择器的扩展应用。而在标签内写入style=的方式,应该是 CSS的一种引入方式,而不是选择器,因为根本就没有用到选择器。而一般人们将上面这几种方式结合在一起,所以就有了5种或6种选择器了。三种基本的选择器类型语法如下:标签名选择器,如:p,即直接使用 HTML标签作为选择器。类选择器,如.polaris。ID 选择器,如#polaris。注意,ID 选择器跟类

3、选择器有很大的不同:一个页面内不能出现相同的 ID;再就是ID也是后台开发人员会经常用的,所以前端开发人员应该尽量少的使用。当然跟后台人员的工作配合十分娴熟之后,这些都不会成为限制。扩展选择器后代选择器,如.polaris span img,后代选贼器实际上是使用多个选择器加上中间的空格来找到具体的要控制标签。群组选择器,如 div,span,img,群组选择器实际上是对 CSS的一种简化写法,只不过把有相同定义的不同选择器放在一起,省了很多代码。选择器的优先级别了解了各种选择器后,还有一个重要的知识点就是 CSS选择器的优先级。这也就是为什么 polaris会遇到文章开头的问题。举个简单的例

4、子: beijixing polaris 如果已经把.polaris 下面 span内的字体设置成红色: .polaris span color:red; 这时,如果要改变.beijixing 的颜色为蓝色,用下面的命令是不能实现的: .beijixing color:blue; 出现这种情况就是因为后一个命令的优先级不够,两条相互冲突的样式设置,浏览器只会执行优先级较高的那个。那么选择器的优先级是怎么规定的呢?一般而言,选择器越特殊,它的优先级越高。也就是选择器指向的越准确,它的优先级就越高。通常我们用1表示标签名选择器的优先级,用10表示类选择器的优先级,用100标示 ID选择器的优先级。

5、比如上例当中 .polaris span color:red;的选择器优先级是 10 + 1 也就是11;而 .polaris 的优先级是10;浏览器自然会显示红色的字。理解了这个道理之后下面的优先级计算自是易如反掌: div.test1 .span var 优先级 1+10 +10 +1 span#xxx .songs li 优先级1+100 + 10 + 1 #xxx li 优先级 100 +1 对于什么情况下使用什么选择器,用不同选择器的原则是:第一:准确的选到要控制的标签;第二:使用最合理优先级的选择器;第三:HTML 和 CSS代码尽量简洁美观。通常:1、最常用的选择器是类选择器。2

6、、li、td、dd 等经常大量连续出现,并且样式相同或者相类似的标签,我们采用类选择器跟标签名选择器结合的后代选择器 .xx li/td/dd 的方式选择。3、极少的情况下会用 ID选择器,当然很多前端开发人员喜欢header,footer,banner,conntent 设置成 ID选择器的,因为相同的样式在一个页面里不可能有第二次。在这里不得不提使用在标签内引入 CSS的方式来写 CSS,即: polaris 这时候的优先级是最高的。我们给它的优先级是1000,这种写法不推荐使用,特别是对新手来说。这也完全违背了内容和显示分离的思想。DIV+CSS 的优点也不能再有任何体现。后代选择器的定

7、位原则在这里介绍一下对于后代选择器,浏览器是如何查找元素的呢?浏览器 CSS匹配不是从左到右进行查找,而是从右到左进行查找。比如 DIV#divBox p span.redcolor:red;,浏览器的查找顺序如下:先查找 html中所有 class=red的 span元素,找到后,再查找其父辈元素中是否有 p元素,再判断 p的父元素中是否有 id为divBox的 div元素,如果都存在则匹配上。浏览器从右到左进行查找的好处是为了尽早过滤掉一些无关的样式规则和元素。比如如下 html和 css: DIV#divBox p span.redcolor:red; s1 s2 s3 s4 如果按从左

8、到右查找,哪会先查找到很多不相关的 p和 span元素。而如果按从左到右的方式进行查找,则首先就查找到的元素。firefox 称这种查找方式为 key selector(关键字查询),所谓的关键字就是样式规则中最后(最右边)的规则,上面的 key就是 span.red。简洁、高效的 CSS所谓高效的 CSS就是让浏览器在查找 style匹配的元素的时候尽量进行少的查找,下面列出一些我们常见的写 CSS犯一些低效错误:不要在 ID选择器前使用标签名一般写法:DIV#divBox更好写法:#divBox解释: 因为 ID选择器是唯一的,加上 div反而增加不必要的匹配。不要再 class选择器前使用标签名一般写法:span.red更好写法:.red解释:同第一条,但如果你定义了多个.red,而且在不同的元素下是样式不一样,则不能去掉,比如你 css文件中定义如下: p.redcolor:red; span.redcolor:#ff00ff 如果是这样定义的就不要去掉,去掉后就会混淆,不过建议最好不要这样写尽量少使用层级关系一般写法:#divBox p .redcolor:red;更好写法:.red.使用 class代替层级关系一般写法:#divBox ul li adisplay:block;更好写法:.blockdisplay:block;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号