日期:2013-07-29  浏览次数:21310 次

如今IE7曾经推出一段时间并且渗透到用户当中,不用等太久我们就可以在页面上使用更高级的CSS。两个最有用的项目将是 Child子和Adjacent Sibling相邻兄弟选择符。如今已是时候使用它们制造网页,并且更深入研讨它们。

留意,选择器包括现行的符号,“>”,“+”和空格(后代选择符),涉及到子选择器,相邻兄弟选择器,后代选择器,统称为选择符。

一个较好的方法

在我们研讨选择符之前,弄清楚他们的不同和为什么它们是好东西的缘由是个不错的主意。缘由很简单,它减少网页的“class-itis”弊病。次要缘由就是“class-itis”在目前网页中非常普遍,直到如今,我们拥有了为建立配合CSS选择器而存在而且支持完满的后代选择符,即两个选择器之间空格。

当使用后代选择符,左边的一个元素选择器是被选择的,不管左边的元素选择器标签有几个。举例,p a{color:red;},意思是段落里面的所有链接都是红色。这非常有用,也是一类相当广泛的选择组合。

代表性的class-itis的级数像下面一样。首先,你使用一个非常好的干净的html结构运用简单的CSS款式构建标题、段落等等。然后有人通知你每个div块第一段里文本颜色需求红色。你不能仅改变目标段落的款式,由于那可能影响全部,所以你被迫命名一个特殊class使用在第一段。

于是数十次相反的要求在后面继续,结果就构成了class-itis景象。为什么说这样是蹩脚无害的?由于这和font标签比起来没什么区别。当然,classes允许无穷的花样,但是紧随其后就是无穷的混乱,或可能更快胜于随后。

举个例子,假设你曾经给所有第一段加上class属性,而且一切都好。如今你被告知,首两段需求款式,不只是第一个。为使用正确class完成目的,你必须确信第二段的每个都有公用的class。最后,这样的习惯导致源代码里四处都是class,感觉像新旧两个款式在打斗冲突,让人头痛。

如果我们只针对CSS讲这样未必不好,实际上“运用下列款式到每个div块第一段和第二段里面。”这样的情况发生了,最新的CSS选择符允许我们耍点小聪明就可办到。

回顾复习下

让我们复习一些术语。W3C CSS2.1 规范解释了选择器(selectors)和选择(combinators):

“一个选择器是用选择符连接起来的一个或更多的选择器。选择符包括:空格,‘>’和‘+’。空格可能出如今一个选择符和简单的选择器之间。”一个简单的选择器可以是一品种型选择器或是通用选择器跟随零或者更多属性选择器,ID选择器或者伪类,在任何顺序。

第一个支持的选择符(也经常被称作选择器,这是独一正确的部分)是子选择符。在简单的选择器之间指定“>”符号。一个简单的例子,#leftcol>p{color:blue;},意思是#leftcol下面所有子段落文本颜色是蓝色。

但是如果#leftcol有一个DIV,而且DIV还有一个段落,#left>p选择器不会使这个段落里的文本变成蓝色,由于子选择符,不像频繁使用的后代选择符,只选择直接的孩子,不是“>”符号的左边元素任何深度的嵌套后代。

另外一个新支持的选择符将是相邻选择符,使用"+"符号。子选择符可以指向另外一个元素的子部,相邻选择符可以指向跟随的元素,但与前面的元素独立。例子,h2+p {color:blue;},跟随h2元素后面段落的文本颜色为蓝色。

如今你明白选择符怎样任务,我们开始研讨复杂联合元素,看看我们能不能不使用class达到目的。

作者:John Gallant , Holly Bergevin 翻译:w3cpro.cn

原文地址:http://www.communitymx.com/content/article.cfm?cid=1C603

翻译地址:http://www.w3cpro.cn/article/xhtmlcss/124.html