• CSS 伪类 (Pseudo-classes)


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

    CSS 伪类 (Pseudo-classes)实例:

    超链接
    本例演示如何向文档中的超链接添加不同的颜色。
    超链接 2
    本例演示如何向超链接添加其他样式。
    超链接 - :focus 的使用
    本例演示如何对超链接应用 :focus 伪类(无法在 IE 中工作)。
    :first-child(首个子对象)
    本例演示 :first-child 伪类的用法。
    :lang(语言)
    本例演示 :lang 伪类的用法。

    语法

    伪类的语法:

    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 伪类来选择元素的第一个子元素。这个特定伪类很容易遭到误解,所以有必要举例来说明。考虑以下标记:

    <div>
    <p>These are the necessary steps:</p>
    <ul>
    <li>Intert Key</li>
    <li>Turn key <strong>clockwise</strong></li>
    <li>Push accelerator</li>
    </ul>
    <p>Do <em>not</em> push the brake at the same time as the accelerator.</p>
    </div>
    

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

    给定以下规则:

    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 元素:

    <html>
    <head>
    <style type="text/css">
    p:first-child {
      color: red;
      } 
    </style>
    </head>
    
    <body>
    <p>some text</p>
    <p>some text</p>
    </body>
    </html>

    TIY

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

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

    <html>
    <head>
    <style type="text/css">
    p > i:first-child {
      font-weight:bold;
      } 
    </style>
    </head>
    
    <body>
    <p>some <i>text</i>. some <i>text</i>.</p>
    <p>some <i>text</i>. some <i>text</i>.</p>
    </body>
    </html>

    TIY

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

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

    <html>
    <head>
    <style type="text/css">
    p:first-child i {
      color:blue;
      } 
    </style>
    </head>
    
    <body>
    <p>some <i>text</i>. some <i>text</i>.</p>
    <p>some <i>text</i>. some <i>text</i>.</p>
    </body>
    </html>

    TIY

    CSS2 - :lang 伪类

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

    <html>
    <head>
    
    <style type="text/css">
    q:lang(no)
       {
       quotes: "~" "~"
       }
    </style>
    
    </head>
    
    <body>
    <p>文字<q lang="no">段落中的引用的文字</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

    CSS 伪元素 (Pseudo-elements)

    CSS 伪元素用于向某些选择器设置特殊效果。

    语法

    伪元素的语法:

    selector:pseudo-element {property:value;}

    CSS 类也可以与伪元素配合使用:

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

    :first-line 伪元素

    "first-line" 伪元素用于向文本的首行设置特殊样式。

    在下面的例子中,浏览器会根据 "first-line" 伪元素中的样式对 p 元素的第一行文本进行格式化:

    实例

    p:first-line
      {
      color:#ff0000;
      font-variant:small-caps;
      }
    

    亲自试一试

    注释:"first-line" 伪元素只能用于块级元素。

    注释:下面的属性可应用于 "first-line" 伪元素:

    • font
    • color
    • background
    • word-spacing
    • letter-spacing
    • text-decoration
    • vertical-align
    • text-transform
    • line-height
    • clear

    :first-letter 伪元素

    "first-letter" 伪元素用于向文本的首字母设置特殊样式:

    p:first-letter
      {
      color:#ff0000;
      font-size:xx-large;
      }
    

    亲自试一试

    注释:"first-letter" 伪元素只能用于块级元素。

    注释:下面的属性可应用于 "first-letter" 伪元素:

    • font
    • color
    • background
    • margin
    • padding
    • border
    • text-decoration
    • vertical-align (仅当 float 为 none 时)
    • text-transform
    • line-height
    • float
    • clear

    伪元素和 CSS 类

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

    p.article:first-letter
      {
      color: #FF0000;
      }
    
    <p class="article">This is a paragraph in an article。</p>
    

    上面的例子会使所有 class 为 article 的段落的首字母变为红色。

    多重伪元素

    可以结合多个伪元素来使用。

    在下面的例子中,段落的第一个字母将显示为红色,其字体大小为 xx-large。第一行中的其余文本将为蓝色,并以小型大写字母显示。段落中的其余文本将以默认字体大小和颜色来显示:

    p:first-letter
      {
      color:#ff0000;
      font-size:xx-large;
      }
    
    p:first-line
      {
      color:#0000ff;
      font-variant:small-caps;
      }
    

    亲自试一试

    CSS2 - :before 伪元素

    ":before" 伪元素可以在元素的内容前面插入新内容。

    下面的例子在每个 <h1> 元素前面插入一幅图片:

    h1:before
      {
      content:url(logo.gif);
      }
    

    亲自试一试

    CSS2 - :after 伪元素

    ":after" 伪元素可以在元素的内容之后插入新内容。

    下面的例子在每个 <h1> 元素后面插入一幅图片:

    h1:after
      {
      content:url(logo.gif);
      }
    

    亲自试一试

    伪元素

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

    属性描述CSS
    :first-letter 向文本的第一个字母添加特殊样式。 1
    :first-line 向文本的首行添加特殊样式。 1
    :before 在元素之前添加内容。 2
    :after 在元素之后添加内容。 2
  • 相关阅读:
    Jetpack MVVM 高频提问和解答
    Android-Jetpack架构组件-—-Navigation#
    Jetpack明星组件 —ViewModel #
    Android开发把 LiveData 用于事件传递那些坑#
    Android官方架构组件Lifecycle#
    Android架构组件JetPack之Lifecycle#
    Android架构组件JetPack之LiveData的工作原理#
    DataBinding从入门到通透#
    SpringBoot 分包方式多数据源
    SpringBoot与数据访问
  • 原文地址:https://www.cnblogs.com/cp168168/p/5792944.html
Copyright © 2020-2023  润新知