CSS 伪类 (Pseudo-classes)
CSS 伪类用于向某些选择器添加特殊的效果。
语法
伪类的语法:
1 | selector : pseudo-class {property: value} |
CSS 类也可与伪类搭配使用。
1 | selector.class : pseudo-class {property: value} |
锚伪类
在支持 CSS 的浏览器中,链接的不同状态都可以不同的方式显示,这些状态包括:活动状态,已被访问状态,未被访问状态,和鼠标悬停状态。
1 2 3 4 | < code >a:link</ code > { color : #FF0000 } /* 未访问的链接 */ < code >a:visited</ code > { color : #00FF00 } /* 已访问的链接 */ < code >a:hover</ code > { color : #FF00FF } /* 鼠标移动到链接上 */ < code >a:active</ code > { color : #0000FF } /* 选定的链接 */ |
提示:在 CSS 定义中,a:hover 必须被置于 a:link 和 a:visited 之后,才是有效的。
提示:在 CSS 定义中,a:active 必须被置于 a:hover 之后,才是有效的。
提示:伪类名称对大小写不敏感。
伪类与 CSS 类
伪类可以与 CSS 类配合使用:
1 2 3 | a< code >. red </ code > : visited { color : #FF0000 } <a class= "<code>red</code>" href= "css_syntax.asp" >CSS Syntax</a> |
假如上面的例子中的链接被访问过,那么它将显示为红色。
CSS2 - :first-child 伪类
您可以使用 :first-child 伪类来选择元素的第一个子元素。这个特定伪类很容易遭到误解,所以有必要举例来说明。考虑以下标记:
1 2 3 4 5 6 7 8 9 | <div> < code ><p>These are the necessary steps:</p></ code > <ul> < code ><li>Intert Key</li></ code > <li>Turn key < code ><strong>clockwise</strong></ code ></li> <li>Push accelerator</li> </ul> <p>Do < code ><em>not</em></ code > push the brake at the same time as the accelerator.</p> </div> |
在上面的例子中,作为第一个元素的元素包括第一个 p、第一个 li 和 strong 和 em 元素。
给定以下规则:
1 2 | p:first-child { font-weight : bold ;} li:first-child { text-transform : uppercase ;} |
第一个规则将作为某元素第一个子元素的所有 p 元素设置为粗体。第二个规则将作为某个元素(在 HTML 中,这肯定是 ol 或 ul 元素)第一个子元素的所有 li 元素变成大写。
请访问该链接,来查看这个 :first-child 实例的效果。
提示:最常见的错误是认为 p:first-child 之类的选择器会选择 p 元素的第一个子元素。
注释:必须声明 <!DOCTYPE>,这样 :first-child 才能在 IE 中生效。
为了使您更透彻地理解 :first-child 伪类,我们另外提供了 3 个例子:
例子 1 - 匹配第一个 <p> 元素
在下面的例子中,选择器匹配作为任何元素的第一个子元素的 p 元素:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <html> <head> <style type= "text/css" > < code >p:first-child</ code > { color : red ; } </style> </head> <body> < code ><p>some text</p></ code > <p>some text</p> </body> </html> |
例子 2 - 匹配所有 <p> 元素中的第一个 <i> 元素
在下面的例子中,选择器匹配所有 <p> 元素中的第一个 <i> 元素:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <html> <head> <style type= "text/css" > < code >p > i:first-child</ code > { font-weight : bold ; } </style> </head> <body> <p>some < code ><i>text</i></ code >. some <i>text</i>.</p> <p>some < code ><i>text</i></ code >. some <i>text</i>.</p> </body> </html> |
例子 3 - 匹配所有作为第一个子元素的 <p> 元素中的所有 <i> 元素
在下面的例子中,选择器匹配所有作为元素的第一个子元素的 <p> 元素中的所有 <i> 元素:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | <html> <head> <style type= "text/css" > < code >p:first-child i</ code > { color : blue ; } </style> </head> <body> <p>some < code ><i>text</i></ code >. some < code ><i>text</i></ code >.</p> <p>some <i>text</i>. some <i>text</i>.</p> </body> </html> |
CSS2 - :lang 伪类
:lang 伪类使你有能力为不同的语言定义特殊的规则。在下面的例子中,:lang 类为属性值为 no 的 q 元素定义引号的类型:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <html> <head> <style type= "text/css" > < code >q:lang(no) { quotes : "~" "~" }</ code > </style> </head> <body> <p>文字<q < code >lang= "no" </ code >>段落中的引用的文字</q>文字</p> </body></html> |
伪类
W3C:"W3C" 列指示出该属性在哪个 CSS 版本中定义(CSS1 还是 CSS2)。
属性 | 描述 | CSS |
---|---|---|
:active | 向被激活的元素添加样式。 | 1 |
:focus | 向拥有键盘输入焦点的元素添加样式。 | 2 |
:hover | 当鼠标悬浮在元素上方时,向元素添加样式。 | 1 |
:link | 向未被访问的链接添加样式。 | 1 |
:visited | 向已被访问的链接添加样式。 | 1 |
:first-child | 向元素的第一个子元素添加样式。 | 2 |
:lang | 向带有指定 lang 属性的元素添加样式。 | 2 |