转载

CSS 伪类 Pseudo-classes

CSS 伪类用于向某些选择器添加特殊的效果。

语法

伪类的语法:

 selector : pseudo-class {property: value}

CSS 类也可与伪类搭配使用。

 selector.class : pseudo-class {property: value}

锚伪类

在支持 CSS 的浏览器中,链接的不同状态都可以不同的方式显示,这些状态包括:活动状态,已被访问状态,未被访问状态,和鼠标悬停状态。

 a:link {color: #FF0000}  /* 未访问的链接 */ a:visited {color: #00FF00} /* 已访问的链接 */ a:hover {color: #FF00FF} /* 鼠标移动到链接上 */ a:active {color: #0000FF} /* 选定的链接 */ 

提示:在 CSS 定义中,a:hover 必须被置于 a:link 和 a:visited 之后,才是有效的。

提示:在 CSS 定义中,a:active 必须被置于 a:hover 之后,才是有效的。

提示:伪类名称对大小写不敏感。

伪类与 CSS 类

伪类可以与 CSS 类配合使用:

 a.red : visited {color: #FF0000}  <a class="red" href="css_syntax.asp">CSS Syntax</a>

假如上面的例子中的链接被访问过,那么它将显示为红色。

CSS2 - :first-child 伪类

您可以使用 :first-child 伪类来选择元素的第一个子元素。这个特定伪类很容易遭到误解,所以有必要举例来说明。考虑以下标记:

  1. <div> 
  2. <p>These are the necessary steps:</p> 
  3. <ul> 
  4. <li>Intert Key</li> 
  5. <li>Turn key <strong>clockwise</strong></li> 
  6. <li>Push accelerator</li> 
  7. </ul> 
  8. <p>Do <em>not</em> push the brake at the same time as the accelerator.</p> 
  9. </div> 

在上面的例子中,作为第一个元素的元素包括第一个 p、第一个 li 和 strong 和 em 元素。

给定以下规则:

  1. p:first-child {font-weightbold;} 
  2. li:first-child {text-transform:uppercase;} 

第一个规则将作为某元素第一个子元素的所有 p 元素设置为粗体。第二个规则将作为某个元素(在 HTML 中,这肯定是 ol 或 ul 元素)第一个子元素的所有 li 元素变成大写。

提示:最常见的错误是认为 p:first-child 之类的选择器会选择 p 元素的第一个子元素。

注释:必须声明 <!DOCTYPE>,这样 :first-child 才能在 IE 中生效。

为了使您更透彻地理解 :first-child 伪类,我们另外提供了 3 个例子:

例子 1 - 匹配第一个 <p> 元素

在下面的例子中,选择器匹配作为任何元素的第一个子元素的 p 元素:

  1. <html> 
  2. <head> 
  3. <style type="text/css"
  4. p:first-child { 
  5.   colorred
  6.   }  
  7. </style> 
  8. </head> 
  9.  
  10. <body> 
  11. <p>some text</p> 
  12. <p>some text</p> 
  13. </body> 
  14. </html> 

例子 2 - 匹配所有 <p> 元素中的第一个 <i> 元素

在下面的例子中,选择器匹配所有 <p> 元素中的第一个 <i> 元素:

  1. <html> 
  2. <head> 
  3. <style type="text/css"
  4. p > i:first-child { 
  5.   font-weight:bold
  6.   }  
  7. </style> 
  8. </head> 
  9.  
  10. <body> 
  11. <p>some <i>text</i>. some <i>text</i>.</p> 
  12. <p>some <i>text</i>. some <i>text</i>.</p> 
  13. </body> 
  14. </html> 

例子 3 - 匹配所有作为第一个子元素的 <p> 元素中的所有 <i> 元素

在下面的例子中,选择器匹配所有作为元素的第一个子元素的 <p> 元素中的所有 <i> 元素:

  1. <html> 
  2. <head> 
  3. <style type="text/css"
  4. p:first-child i { 
  5.   color:blue
  6.   }  
  7. </style> 
  8. </head> 
  9.  
  10. <body> 
  11. <p>some <i>text</i>. some <i>text</i>.</p> 
  12. <p>some <i>text</i>. some <i>text</i>.</p> 
  13. </body> 
  14. </html> 

CSS2 - :lang 伪类

:lang 伪类使你有能力为不同的语言定义特殊的规则。在下面的例子中,:lang 类为属性值为 no 的 q 元素定义引号的类型:

  1. <html> 
  2. <head> 
  3.  
  4. <style type="text/css"
  5. q:lang(no) 
  6.    { 
  7.    quotes"~" "~" 
  8.    } 
  9. </style> 
  10.  
  11. </head> 
  12.  
  13. <body> 
  14. <p>文字<q lang="no">段落中的引用的文字</q>文字</p> 
  15. </body></html> 

伪类

W3C:"W3C" 列指示出该属性在哪个 CSS 版本中定义(CSS1 还是 CSS2)。

Pseudo-Classes
伪类
CSS Version
版本
Compatibility
兼容性
Description
简介
:link CSS1 IE4+ , NS4+ 设置a对象在未被访问前的样式表属性
:hover CSS1/CSS2 IE4+ , NS4+ 设置对象在其鼠标悬停时的样式表属性
:active CSS1/CSS2 IE4+ 设置对象在被用户激活(在鼠标点击与释放之间发生的事件)时的样式表属性
:visited CSS1 IE4+ , NS4+ 设置a对象在其链接地址已被访问过时的样式表属性
:focus CSS2 NONE 设置对象在成为输入焦点(该对象的onfocus事件发生)时的样式表属性
:first-child CSS2 NONE 设置对象(Selector1)的第一个子对象(Selector2)的样式表属性
:first CSS2 IE4+ 设置页面容器第一页使用的样式表属性。仅用于@page规则
:left CSS2 IE4+ 设置页面容器位于装订线左边的所有页面使用的样式表属性。仅用于@page规则
:right CSS2 IE4+ 设置页面容器位于装订线右边的所有页面使用的样式表属性。仅用于@page规则
:lang CSS2 NONE 设置对象使用特殊语言的内容样式表属性
正文到此结束
Loading...