CSS伪类与伪元素
邵预鸿 Lv5

为什么要引入伪类与伪元素?

css引入伪类和伪元素概念是为了格式化文档树以外的信息。也就是说,伪类和伪元素是用来修饰不在文档树中的部分,比如,一句话中的第一个字母,或是列表中的第一个元素,又或者是鼠标悬停在某个超链接上时要设置的样式。

什么是伪类,伪元素?

  • 伪类:用于当已有元素处于的某个状态时,为其添加对应的样式,这个状态是根据用户行为而动态变化的。比如说,当用户悬停在指定的元素时,我们可以通过:hover来描述这个元素的状态。虽然它和普通的css类相似,可以为已有的元素添加样式,但是它只有处于dom树无法描述的状态下才能为元素添加样式,所以将其称为伪类。
  • 伪元素:用于创建一些不在文档树中的元素,并为其添加样式。实际上,伪元素就是选取某些元素前面或后面这种普通选择器无法完成的工作。控制的内容和元素是相同的,但它本身是基于元素的抽象,并不存在于文档结构中。比如说,我们可以通过:before来在一个元素前增加一些文本,并为这些文本添加样式。

伪类的分类:状态伪类和结构性伪类

  • 状态伪类:是基于元素当前状态进行选择的。在与用户的交互过程中元素的状态是动态变化的,因此该元素会根据其状态呈现不同的样式。当元素处于某状态时会呈现该样式,而进入另一状态后,该样式也会失去。

    常见的状态伪类主要包括:

  1. :link 应用于未被访问过的链接;
  2. :hover 应用于鼠标悬停到的元素;
  3. :active 应用于被激活的元素;
  4. :visited 应用于被访问过的链接,与:link互斥。
  5. :focus 应用于拥有键盘输入焦点的元素。
  • 结构性伪类:是css3新增选择器,利用dom树进行元素过滤,通过文档结构的互相关系来匹配元素,能够减少class和id属性的定义,使文档结构更简洁。

    常见的结构性伪类包括:

  1. :first-child 选择某个元素的第一个子元素;
  2. :last-child 选择某个元素的最后一个子元素;
  3. :nth-child() 选择某个元素的一个或多个特定的子元素;
  4. :nth-last-child() 选择某个元素的一个或多个特定的子元素,从这个元素的最后一个子元素开始算;
  5. :nth-of-type() 选择指定的元素;
  6. :nth-last-of-type() 选择指定的元素,从元素的最后一个开始计算;
  7. :first-of-type 选择一个上级元素下的第一个同类子元素;
  8. :last-of-type 选择一个上级元素的最后一个同类子元素;
  9. :only-child 选择的元素是它的父元素的唯一一个子元素;
  10. :only-of-type 选择一个元素是它的上级元素的唯一一个相同类型的子元素;
  11. :empty 选择的元素里面没有任何内容。
  12. :checked匹配被选中的input元素,这个input元素包括radio和checkbox。
  13. :default匹配默认选中的元素,例如:提交按钮总是表单的默认按钮。
  14. :disabled匹配禁用的表单元素。
  15. :enabled匹配没有设置disabled属性的表单元素。
  16. :valid匹配条件验证正确的表单元素。

常见的伪元素选择器:

  1. ::first-letter 选择元素文本的第一个字(母)。
  2. ::first-line 选择元素文本的第一行。
  3. ::before 在元素内容的最前面添加新内容。
  4. ::after 在元素内容的最后面添加新内容。
  5. ::selection匹配用户被用户选中或者处于高亮状态的部分
  6. ::placeholder匹配占位符的文本,只有元素设置了placeholder属性时,该伪元素才能生效

注意:你会发现伪类元素使用了两个冒号 (::) 而不是一个冒号 (:),这是 CSS3 规范中的一部分要求,目的是为了区分伪类和伪元素,大多数浏览器都支持这两种表示方式。单冒号(:)用于 CSS3 伪类,双冒号(::)用于 CSS3 伪元素。对于 CSS2 中已经有的伪元素,例如 :before,单冒号和双冒号的写法 ::before 作用是一样的。

  • 本文标题:CSS伪类与伪元素
  • 本文作者:邵预鸿
  • 创建时间:2021-02-21 12:05:33
  • 本文链接:/images/logo.jpg2021/02/21/CSS伪类与伪元素/
  • 版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!