百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

关于CSS伪类&伪元素的一些知识——CSS学习之路

zhezhongyun 2025-05-16 18:03 2 浏览

最近两天接触到了CSS伪类伪元素之间的关系,伪类和伪元素在css代码中使用:做标识符,同来识别元素。我倒是理解,可是为什么时常见到一会用一个冒号,一会用两个,然后就感觉很迷糊了,于是就有了这一篇文章。

伪类和伪元素,对于绝大多数同学来说,都是耳熟能详的名字,但确实又有很多人搞不清楚它们之间的区别,以致于混淆概念。而当概念都混淆的时候,也往往意味着你不会经常使用它,怕出错,怕用不好。而这也会大大影响你的效率,本来几行代码就可以完成的工作,却要写上一大堆。。。

所以,花点时间理清楚每一个看似微小的概念,会让我们的编程更有效率。下面进入正题。

伪类和伪元素的区别,其实很简单,从字面上就可以理解。它们有一个共同的修饰词“”,那么“伪”是什么意思呢?就是假的意思了。但是又似是不是。比如我们在电视剧里经常听说到的伪军。

所以,伪类就是假的类,伪元素就是假的元素,这就是在字面上它们之间的区别。下面我们再从定义上感受一下。

对于开头提到的问题,这事还得从头说起:

很多年前,Chrome浏览器还没出身,IE9还未出现的时候,first-letter那时候还叫做伪类选择器,写法是一个冒号,如:first-letter,那时候的语义要更直白一些,选择第一个字符,然后设置一些样式。后来,伪类和伪元素被划分地更加明确和规范了。

:active,:link, :focus, :checked等等被称为伪类。

::after,::before, ::backdrop, ::first-letter, ::first-line, ::selection是伪元素。

那到底什么是伪类,什么是伪元素呢?

1.伪类

CSS3给出的定义是:

The pseudo-class concept is introduced to permit selection based on information that lies outside of the document tree or that cannot be expressed using the other simple selectors.

大致翻译过来的意思就是:伪类存在的意义是为了通过选择器,格式化DOM树以外的信息以及不能被常规CSS选择器获取到的信息。

通过上面的概念我们知道了伪类的功能有两种:

1.格式化DOM树以外的信息。比如: <a> 标签的:link、:visited 等。这些信息不存在于DOM树中。

2.不能被常规CSS选择器获取到的信息。比如:要获取第一个子元素,我们无法用常规的CSS选择器获取,但可以通过 :first-child 来获取到。

2.伪元素

CSS3给出的定义如下:

Pseudo-elements create abstractions about the document tree beyond those specified by the document language. For instance, document languages do not offer mechanisms to access the first letter or first line of an element's content. Pseudo-elements allow authors to refer to this otherwise inaccessible information. Pseudo-elements may also provide authors a way to refer to content that does not exist in the source document (e.g., the ::before and ::after pseudo-elements give access to generated content).

大致翻译过来的意思就是:伪元素可以创建一些文档语言无法创建的虚拟元素。比如:文档语言没有一种机制可以描述元素内容的第一个字母或第一行,但伪元素可以做到(::first-letter、::first-line)。同时,伪元素还可以创建源文档不存在的内容,比如使用 ::before 或 ::after。

3.伪类和伪元素的区别(CSS3下的区别)

通过上面的概念,我们就可以知道伪类与伪元素最本质的一个区别:

伪类其实是弥补了CSS选择器的不足,用来更方便地获取信息。

如下面的例子:

<ul>
 <li>11111</li>
 <li>22222</li>
</ul> 
li:first-child {
 color: red; 
}
// 选择器不能直接选取第一个子元素
// 伪类弥补了选择器的不足

而伪元素本质上是创建了一个虚拟容器(元素),我们可以在其中添加内容或样式。

<p>
 <span class="first-letter">H</span>ello, World
</p>
CSS:
.first-letter {
 color: red;
}

上面的代码其实就是:

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

所以,你可以理解伪元素本质上是创建了一个虚拟容器(元素)了吧。

除了上面这个本质区别以外,在CSS3中,伪类用单冒号:表示;而伪元素用双冒号::表示。一个选择器可以同时使用多个伪类(但有的伪类会互斥);而一个选择器只能同时使用一个伪元素(未来的版本可能会支持多伪元素)。

4.主要用法

4.1伪类

(1) :first-child 匹配第一个子元素。

<ul>
 <li>111</li>
 <li>222</li>
</ul> 
li:first-child {
 color: red; // 第一个 li 会变红
}

(2):last-child 匹配最后一个子元素。

<ul>
 <li>aaa</li>
 <li>bbb</li>
 <li>ccc</li>
</ul>
li:last-child {
 color:red; // 最后一个 li 会变红
}

(3):first-of-type 匹配属于其父元素的第一个特定类型的子元素。

<div>
 <h1>h1文本</h1>
 <p>p文本</p>
</div>
p:first-of-type {
 color: red; // <p>标签的内容变为红色
}

这里有必要强调一下 :first-child 与 :first-of-type 的区别。如果你的CSS写成:

p:first-child {
 color:red;
}

页面是不会有变化的,因为<p>元素并不是父元素<div>的第一个子元素。

(4):last-of-type 匹配属于其父元素的最后一个特定类型的子元素。

<div>
 <h1>h1文本</h1>
 <h1>h1文本2</h1>
 <p>p文本</p>
</div>
h1:last-of-type {
 color: red; // 倒数第一个<h1>标签的内容变为红色(h1文本2)
}

4.2伪元素

(1)::before

在被选元素之前插入内容。需要指定content属性来插入内容。

<p>CSS</p>
p::before {
 content: "Hi,";
}

(2)::after

在被选元素之后插入内容。需要指定content属性来插入内容。

<p>Hi, </p>
p::after {
 content: "CSS";
}

(3)::first-letter匹配元素中文本的首字母。

<p>我在学伪元素</p>

注意:试试把<p>标签改成<p>???我在学伪元素</p>,你会发现很有意思的现象。

p::first-letter {
 font-size: 32px;
}

(4)::first-line

匹配元素中第一行的文本(只能在块元素中使用)。

<p>我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素</p>

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

(5) ::selection 匹配被用户选中的部分

<p>我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素,我在学伪元素</p>
p::selection {
 color: red;
}

总结一下伪类与伪元素的特性及其区别:

1、伪类本质上是为了弥补常规CSS选择器的不足,以便获取到更多信息;

2、伪元素本质上是创建了一个有内容的虚拟容器;

3、CSS3中伪类和伪元素的语法不同;

伪类 :link,:hover

伪元素 ::before ::after

4、可以同时使用多个伪类,而只能同时使用一个伪元素;

5、其中伪类和伪元素的根本区别在于:它们是否创造了新的元素,, 这个新创造的元素就叫 "伪无素" 。

6、伪元素/伪对象:不存在在DOM文档中,是虚拟的元素,是创建新元素。 这个新元素(伪元素) 是某个元素的子元素,这个子元素虽然在逻辑上存在,但却并不实际存在于文档树中.

7、伪类:存在DOM文档中,(无标签,找不到, 只有符合触发条件时才能看到 ), 逻辑上存在但在文档树中却无须标识的“幽灵”分类。

8、因为伪类是类似于添加类所以可以是多个,而伪元素在一个选择器中只能出现一次,并且只能出现在末尾。

相关推荐

关于CSS伪类&amp;伪元素的一些知识——CSS学习之路

最近两天接触到了CSS伪类和伪元素之间的关系,伪类和伪元素在css代码中使用:做标识符,同来识别元素。我倒是理解,可是为什么时常见到一会用一个冒号,一会用两个,然后就感觉很迷糊了,于是就有了这一篇文章...

CSS中before 和after的用法

CSS有两个说不上常用的伪类:before和:after,偶尔会被人用来添加些自定义格式什么的,但是它们的功用不仅于此。一基本语法在了解进阶的应用之前,先来了解一下语法规则。平常仅仅需要将这...

CSS 样式总翻车?5 个实战技巧让布局效率暴增 200%!

前端工程师们,是不是经常遇到这种崩溃瞬间?精心设计的CSS样式,一到不同浏览器就“变形走样”,或是响应式布局怎么调都达不到预期效果,改来改去不仅浪费时间,还容易产生一堆冗余代码。别慌!今天带来...

微信小程序入门教程之二:页面样式

这个系列的上一篇教程,教大家写了一个最简单的Helloworld微信小程序。但是,那只是一个裸页面,并不好看。今天接着往下讲,如何为这个页面添加样式,使它看上去更美观,教大家写出实际可以使用的页...

网格不迷路:用 CSS 网格生成器打造完美布局

前言你是否曾因写错grid-template-areas而捶键盘?是否在面对千层嵌套的复杂布局时,瞬间怀疑人生,甚至思考要不要转行去卖奶茶?别慌,CSS网格生成器闪亮登场,像拼乐高一样,帮你轻松...

MFC转QT:Qt高级特性 - 样式表

Qt样式表概述Qt样式表(QtStyleSheets)是基于CSS的样式系统,允许开发者以类似于Web前端的方式定制Qt应用程序的外观。这一特性极大地简化了Qt应用的界面定制,提供了比MFC更强大...

什么是CSS?

CSS是一种用来描述网页样式的语言,它可以控制HTML元素的颜色、大小、位置、布局等外观效果。CSS的全称是层叠样式表(CascadingStyleSheets),它的基本语法由选择器和...

从零开始学习网站CSS布局

CSS是前端开发中的重要技术之一,而CSS布局则是CSS技术中最基础的一部分。学习CSS布局是Web开发者的必修课,也是掌握CSS技能的基石。CSS布局指的是如何使用CSS定位和排版HTML元素。CS...

CSS3 渐变类型及其语法

线性渐变:CSS3可以让背景产生渐变效果,渐变属性有两种,即linear-gradient(线性渐变)和radial-gradient(圆形渐变),语法如下background:linear-gra...

五大顶级CSS性能优化工具,值得程序员一试!

为什么Web页面的加载速度如此重要?在这个信息化的时代,如果一个网站的加载时间过长,大部分用户会极其不耐烦地选择“关掉”!这让辛辛苦苦熬夜敲代码的程序员们情何以堪,不管网站功能如何强大,用户根本都没来...

get css中的clamp()函数,好用到起飞

CSS中有大量令人惊叹的属性和特性,但似乎没有人谈论的是clamp函数。这个函数让我们可以对任何CSS属性执行min-width,max-width,和之类的操作。CSSclamp语法cl...

Google Chrome终于支持CSS Variables了

这篇文章要报道的并不是“新闻”,因为W3C早已开始着手CSS变量(又称‘自定义属性’)方面的工作。而作为CSS4非正式标准的一部分,Mozilla早在Firefox版本号还是29的时候就已经支持它了。...

CSS3 过渡与动画

在现代网页设计中,平滑的过渡和生动的动画效果已成为提升用户体验不可或缺的元素。CSS3为我们提供了强大的transition和animation属性,让开发者能够轻松实现各种视觉效果。本文将...

css基础篇11--表格样式

目标表格边框合并表格边框的间距设置表格标题位置的设置表格可以说是网页必备的元素之一,但是原生的表格样式都是很丑,列如表格加入边框的默认情况下,单元格与单元格之间有一定的空隙;设置单元格边框间距等等,都...

WebDriver-工具辅助生成XPath语法和CSS语法

1.FireBug插件1.1生成XPath语法打开Firefox浏览器FireBug插件,单击插件左上角的鼠标箭头,再单击页面上需要定位的元素,在元素行上右击弹出快捷菜单,选择“复制XPath”,将会...