伪类和伪元素区别

文章类型:CSS

发布者:hp

发布时间:2023-02-08

W3C中对于二者应用的描述:

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

伪元素:用于将特殊的效果添加到某些选择器

区分伪类和伪元素的根本在于:是否创建了新的元素,伪类高于伪元素

相同点:都是属于选择器中的一种,能实现对页面元素的修饰

不同点:

1、概念不同:

伪类:是一种临时状态,一定条件下触发,用于已有元素处于某种状态时为其添加对应的样式,这个状态是根据用户行为而动态变化的;如鼠标悬停效果;

伪元素:是一个dom节点,也称为伪对象,用于创建一些不在DOM树中的元素,并为其添加样式;如:前向后插入元素内容等

2、使用方法不同:

使用双冒号(::)或者单冒号(:)表示伪元素,比如::before和::after等伪元素使用双冒号(::)

使用单冒号(:)表示伪类 比如 :hover和:active

例子:

      <body>
<div>
<p>小白</p>
</div>
</body>

伪类方式

              p:first-child{
color: red;
}

伪元素方式

              p::first-line{
color: red;
}

常用伪类有:

:active 选择正在被激活的元素

:hover 选择被鼠标悬浮着的元素

:link 选择未被访问的元素

:visited 选择已被访问的元素

:first-child 选择满足是其父元素的第一个子元素的元素

:lang(value) 选择带有指定 lang 属性的元素

:focus 选择拥有键盘输入焦点的元素

:enable 选择每个已启动的元素

:disable 选择每个已禁止的元素

:checked 选择每个被选中的元素

:target 选择当前的锚点元素

:first-of-type 选择满足是其父元素的第一个某类型子元素的元素

:last-of-type 选择满足是其父元素的最后一个某类型子元素的元素

:only-of-type 选择满足是其父元素的唯一一个某类型子元素的元素

:nth-of-type(n) 选择满足是其父元素的第n个某类型子元素的元素

:nth-last-of-type(n) 选择满足是其父元素的倒数第n个某类型的元素

:only-child 选择满足是其父元素的唯一一个子元素的元素

:last-child 选择满足是其父元素的最后一个元素的元素

:nth-child(n) 选择满足是其父元素的第n个子元素的元素

:nth-last-child(n) 选择满足是其父元素的倒数第n个子元素的元素

:empty 选择满足没有子元素的元素

:in-range 选择满足值在指定范围内的元素

:out-of-range 选择值不在指定范围内的元素

:invalid 选择满足值为无效值的元素

:valid 选择满足值为有效值的元素

:not(selector) 选择不满足selector的元素

:optional 选择为可选项的表单元素,即没有“required”属性

:read-only 选择有"readonly"的表单元素

:read-write 选择没有"readonly"的表单元素

:root 选择根元素

常用伪元素

::first-letter 选择指定元素的第一个单词

::first-line 选择指定元素的第一行

::after 在指定元素的内容前面插入内容

::before 在指定元素的内容后面插入内容

::selection 选择指定元素中被用户选中的内容