0

0

CSS伪类与伪元素如何使用_常用伪类伪元素解析

P粉602998670

P粉602998670

发布时间:2025-11-20 18:27:10

|

772人浏览过

|

来源于php中文网

原创

伪类用于定义元素状态,如:hover、:focus、:not();伪元素创建抽象内容,如::before、::after、::first-letter,提升样式灵活性与可访问性。

css伪类与伪元素如何使用_常用伪类伪元素解析

伪类和伪元素是CSS中非常实用的特性,它们帮助开发者在不改变HTML结构的前提下,为特定状态或内容片段添加样式。虽然名字相似,但两者用途和语法略有不同。下面详细介绍常用伪类与伪元素的使用方法。

:hover 伪类 —— 鼠标悬停时触发样式

当用户将鼠标指针移动到某个元素上时,:hover 会激活对应样式,常用于按钮、链接等交互元素。

示例:

a:hover { color: red; }
这会让链接在鼠标悬停时变为红色。

不仅限于链接,任何元素都可以使用 :hover,比如高亮整个卡片区域或显示隐藏内容。

:focus 伪类 —— 元素获得焦点时生效

当用户通过键盘Tab键或点击使表单元素(如 input、button)获得焦点时,:focus 被触发,有助于提升可访问性。

立即学习前端免费学习笔记(深入)”;

示例:

input:focus { border-color: blue; outline: none; box-shadow: 0 0 5px blue; }

这样可以让用户清楚地看到当前正在操作的输入框。

::before 和 ::after 伪元素 —— 插入装饰性内容

这两个伪元素允许你在元素内容前或后插入生成的内容,常用于添加图标、引号、清除浮动等。

关键点:
  • 必须设置 content 属性,即使为空(content: "")
  • 默认为行内元素,可通过 display 修改
  • 不能选中或复制生成的内容,仅用于视觉展示
示例:

p::before { content: "▶ "; color: gray; }
每个段落前都会出现一个灰色箭头符号。

:nth-child(n) 与 :nth-of-type(n) —— 精准定位子元素

用于选择父元素下的第n个子元素,适合实现隔行变色、布局控制等。

Programming Helper
Programming Helper

AI代码自动生成器,在AI的帮助下更快地编程

下载
区别说明:
  • :nth-child(2) 选择的是父元素下的第二个子节点,不管类型
  • :nth-of-type(2) 只计算同类型的元素,比如第二个 p 标签
常见用法:

tr:nth-child(even) { background: #f2f2f2; }
实现表格隔行着色。

::first-line 与 ::first-letter —— 文本排版利器

主要用于段落的首行或首字母样式设计,常见于文章页面。

示例:

p::first-letter { font-size: 2em; float: left; margin-right: 5px; }
实现首字母下沉效果。

p::first-line { font-weight: bold; }
让段落首行加粗。

注意:

这些伪元素只能应用于块级元素,且仅对第一个格式化行或字母起作用。

:not() 伪类 —— 排除特定元素

选择不符合指定条件的元素,增强选择器灵活性。

示例:

div:not(.special) { opacity: 0.8; }
所有不包含 class="special" 的 div 都会应用半透明效果。

支持多种参数,如标签名、属性选择器等,提高筛选精度。

总结:伪类 vs 伪元素

伪类以单冒号表示(如 :hover),描述元素的特殊状态;伪元素使用双冒号(如 ::before),代表文档中不存在的抽象元素。

CSS3规范推荐伪元素使用双冒号以区分伪类,但为了兼容旧浏览器,单冒号仍被广泛接受。

合理使用这些特性,能减少冗余HTML标签,让代码更简洁,样式更动态。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
css3教程
css3教程

php中文网为大家提供css3教程合集,CSS3的语法是建立在CSS原先版本基础上的,它允许使用者在标签中指定特定的HTML元素而不必使用多余的class、ID或JavaScript。php中文网还为大家带来css3的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

427

2023.06.14

有哪些css3渐变属性
有哪些css3渐变属性

css3中渐变属性有linear-gradient、radial-gradient、conic-gradient、repeating-linear-gradient、repeating-radial-gradient等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

143

2023.11.01

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

595

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

108

2025.10.23

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

871

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

margin在css中是啥意思
margin在css中是啥意思

在CSS中,margin是一个用于设置元素外边距的属性。想了解更多margin的相关内容,可以阅读本专题下面的文章。

467

2023.12.18

html边框设置教程
html边框设置教程

本教程将带你全面掌握HTML/CSS边框设置,从基础的border属性讲起,涵盖所有边框样式、圆角设置及高级技巧,帮助你快速上手实现各种边框效果。

44

2025.09.02

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号