视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
css属性:css伪类和css伪元素的区别(附代码)
2020-11-27 18:47:46 责编:小采
文档


css伪元素和伪类对于刚学习css的同学来说可能会容易混淆,官方文档中解释:CSS 伪类用于向某些选择器添加特殊的效果,CSS 伪元素是用于将特殊的效果添加到某些选择器。那么,css伪元素和伪类的区别究竟在哪?本文将给大家细细的说道说道。

首先可以明确两点,第一:两者都与选择器相关,第二:就是添加一些“特殊”的效果。这里特殊指的是两者描述了其他 css 无法描述的东西。

伪类种类

伪类
作用
:active
将样式添加到被激活的元素

:focus

将样式添加到被选中的元素
:hover
当鼠标悬浮在元素上方时,向元素添加样式
:link
将特殊样式添加到未被访问过的链接
:visited
将特殊样式添加到被访问过的链接
:first-child
将特殊样式添加到元素的第一个子元素
:lang
允许创造者来定义指定的元素中使用的语言

伪元素种类

伪元素
作用
:first-letter
将特殊样式添加到文本的首字母
:first=line
将特殊样式添加到文本的首行
:before
在某元素之前插入某些内容
:after
在某元素之后插入某些内容

区别

这里用伪类 :first-child 和伪元素 :first-letter 来进行比较。

p>i:first-child {color: red}
<p>
 <i>first</i>
 <i>second</i>
</p>

//伪类 :first-child 添加样式到第一个子元素
如果我们不使用伪类,而希望达到上述效果,可以这样做:

.first-child {color: red}
<p>
 <i class="first-child">first</i>
 <i>second</i>
</p>

即我们给第一个子元素添加一个类,然后定义这个类的样式。那么我们接着看看为元素:

p:first-letter {color: red}
<p>I am stephen lee.</p>

//伪元素 :first-letter 添加样式到第一个字母
那么如果我们不使用伪元素,要达到上述效果,应该怎么做呢?

.first-letter {color: red}
<p><span class='first-letter'>I</span> am stephen lee.</p>

即我们给第一个字母添加一个 span,然后给 span 增加样式。
两者的区别已经出来了。那就是:

伪类的效果可以通过添加一个实际的类来达到,而伪元素的效果则需要通过添加一个实际的元素才能达到,这也是为什么他们一个称为伪类,一个称为伪元素的原因。

最后

伪元素和伪类之所以这么容易混淆,是因为他们的效果类似而且写法相仿,但实际上 css3 为了区分两者,已经明确规定了伪类用一个冒号来表示,而伪元素则用两个冒号来表示。

:Pseudo-classes
::Pseudo-elements

但因为兼容性的问题,所以现在大部分还是统一的单冒号,但是抛开兼容性的问题,我们在书写时应该尽可能养成好习惯,区分两者。

相关文章推荐:

css-伪类和伪元素_html/css_WEB-ITnose

CSS 属性 :before && :after的用法,伪类和伪元素的区别_html/css_WEB-ITnose

什么是CSS伪元素?CSS伪元素用法详解

下载本文
显示全文
专题