Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

CSS 教程

CSS 主页 CSS 简介 CSS 语法 CSS 选择器 CSS 如何 CSS 注释 CSS 颜色 CSS 背景 CSS 边框 CSS 外边距 CSS 内边距 CSS 高度/宽度 CSS 盒模型 CSS 轮廓 CSS 文本 CSS 字体 CSS 图标 CSS 链接 CSS 列表 CSS 表格 CSS 显示 CSS 最大宽度 CSS 位置 CSS Z-index CSS 溢出 CSS 浮动 CSS 行内块 CSS 对齐 CSS 组合器 CSS 伪类 CSS 伪元素 CSS 透明度 CSS 导航栏 CSS 下拉菜单 CSS 图片库 CSS 图片精灵 CSS 属性选择器 CSS 表单 CSS 计数器 CSS 网站布局 CSS 单位 CSS 特定性 CSS !important CSS 数学函数

CSS 高级

CSS 圆角 CSS 边框图片 CSS 背景 CSS 颜色 CSS 颜色关键字 CSS 渐变 CSS 阴影 CSS 文本效果 CSS 网络字体 CSS 2D 变换 CSS 3D 变换 CSS 过渡 CSS 动画 CSS 提示框 CSS 样式图片 CSS 图片反射 CSS object-fit CSS object-position CSS 遮罩 CSS 按钮 CSS 分页 CSS 多列 CSS 用户界面 CSS 变量 CSS @property CSS 盒模型尺寸 CSS 媒体查询 CSS 媒体查询示例 CSS Flexbox

CSS 响应式

RWD 简介 RWD 视窗 RWD 网格视图 RWD 媒体查询 RWD 图片 RWD 视频 RWD 框架 RWD 模板

CSS 网格

网格简介 网格容器 网格项目

CSS SASS

SASS 教程

CSS 示例

CSS 模板 CSS 示例 CSS 编辑器 CSS 代码片段 CSS 问答 CSS 练习 CSS 网站 CSS 面试准备 CSS 集训营 CSS 证书

CSS 参考

CSS 参考 CSS 选择器 CSS 函数 CSS 音频参考 CSS 网络安全字体 CSS 可动画 CSS 单位 CSS PX-EM 转换器 CSS 颜色 CSS 颜色值 CSS 默认值 CSS 浏览器支持

CSS 伪类


什么是伪类?

伪类用于定义元素的特殊状态。

例如,它可以用来

  • 当用户将鼠标悬停在元素上时设置样式
  • 以不同的方式设置已访问和未访问链接的样式
  • 当元素获得焦点时设置样式

将鼠标悬停在我身上


语法

伪类的语法

selector:pseudo-class {
  property: value;
}

锚点伪类

链接可以以不同的方式显示

示例

/* 未访问链接 */
a:link {
  color: #FF0000;
}

/* 已访问链接 */
a:visited {
  color: #00FF00;
}

/* 鼠标悬停在链接上 */
a:hover {
  color: #FF00FF;
}

/* 选定的链接 */
a:active {
  color: #0000FF;
}
自己尝试 »

注意: a:hover 必须在 a:linka:visited 之后出现在 CSS 定义中才能生效! a:active 必须在 a:hover 之后出现在 CSS 定义中才能生效! 伪类名称不区分大小写。



伪类和 HTML 类

伪类可以与 HTML 类结合使用

当您将鼠标悬停在示例中的链接上时,它将改变颜色

示例

a.highlight:hover {
  color: #ff0000;
}
自己尝试 »

将鼠标悬停在 <div> 上

在 <div> 元素上使用 :hover 伪类的示例

示例

div:hover {
  background-color: blue;
}
自己尝试 »

简单的工具提示悬停

将鼠标悬停在 <div> 元素上以显示 <p> 元素(像工具提示一样)

将鼠标悬停在我身上以显示 <p> 元素。

瞧!我在这里!

示例

p {
  display: none;
  background-color: yellow;
  padding: 20px;
}

div:hover p {
  display: block;
}
自己尝试 »

CSS - :first-child 伪类

:first-child 伪类匹配作为另一个元素的第一个子元素的指定元素。

匹配第一个 <p> 元素

在以下示例中,选择器匹配作为任何元素的第一个子元素的任何 <p> 元素

示例

p:first-child {
  color: blue;
}
自己尝试 »

匹配所有 <p> 元素中的第一个 <i> 元素

在以下示例中,选择器匹配所有 <p> 元素中的第一个 <i> 元素

示例

p i:first-child {
  color: blue;
}
自己尝试 »

匹配所有第一个子元素 <p> 元素中的所有 <i> 元素

在以下示例中,选择器匹配作为另一个元素的第一个子元素的 <p> 元素中的所有 <i> 元素

示例

p:first-child i {
  color: blue;
}
自己尝试 »

CSS - :lang 伪类

:lang 伪类允许您为不同的语言定义特殊规则。

在下面的示例中,:lang 为具有 lang="no" 的 <q> 元素定义引号

示例

<html>
<head>
<style>
q:lang(no) {
  quotes: "~" "~";
}
</style>
</head>
<body>

<p>一些文字 <q lang="no">段落中的引用</q> 一些文字。</p>

</body>
</html>
自己尝试 »

更多示例

为超链接添加不同的样式
此示例演示了如何为超链接添加其他样式。

使用 :focus
此示例演示了如何使用 :focus 伪类。


通过练习测试自己

练习

将鼠标悬停在链接上时,将背景颜色设置为红色。

<style>
 {
  background-color: red;
}
</style>

<body>

<h1>This is a header.</h1>
<p>This is a paragraph.</p>
<a href="https://w3schools.com">This is a link.</a>

</body>

开始练习


所有 CSS 伪类

选择器 示例 示例说明
:active a:active 选择活动链接
:checked input:checked 选择每个选中的 <input> 元素
:禁用 input:禁用 选择所有禁用的<input>元素
:空 p:空 选择所有没有子元素的<p>元素
:启用 input:启用 选择所有启用的<input>元素
:第一个子元素 p:第一个子元素 选择所有作为其父元素第一个子元素的<p>元素
:第一个同类型元素 p:第一个同类型元素 选择所有作为其父元素第一个<p>元素的<p>元素
:聚焦 input:聚焦 选择获得焦点的<input>元素
:悬停 a:悬停 选择鼠标悬停时的链接
:在范围内 input:在范围内 选择具有在指定范围内的值的<input>元素
:无效 input:无效 选择所有具有无效值的<input>元素
:语言(语言) p:语言(it) 选择所有lang属性值以"it"开头的<p>元素
:最后一个子元素 p:最后一个子元素 选择所有作为其父元素最后一个子元素的<p>元素
:最后一个同类型元素 p:最后一个同类型元素 选择所有作为其父元素最后一个<p>元素的<p>元素
:链接 a:链接 选择所有未访问的链接
:非(选择器) :非(p) 选择所有不是<p>元素的元素
:第n个子元素(n) p:第n个子元素(2) 选择所有作为其父元素第二个子元素的<p>元素
:倒数第n个子元素(n) p:倒数第n个子元素(2) 选择所有作为其父元素倒数第二个子元素的<p>元素
:倒数第n个同类型元素(n) p:倒数第n个同类型元素(2) 选择所有作为其父元素倒数第二个<p>元素的<p>元素
:第n个同类型元素(n) p:第n个同类型元素(2) 选择所有作为其父元素第二个<p>元素的<p>元素
:唯一同类型元素 p:唯一同类型元素 选择所有作为其父元素唯一<p>元素的<p>元素
:唯一子元素 p:唯一子元素 选择所有作为其父元素唯一子元素的<p>元素
:可选 input:可选 选择没有"required"属性的<input>元素
:超出范围 input:超出范围 选择具有在指定范围之外的值的<input>元素
:只读 input:只读 选择具有指定"readonly"属性的<input>元素
:读写 input:读写 选择没有"readonly"属性的<input>元素
:必填 input:必填 选择具有指定"required"属性的<input>元素
:根 选择文档的根元素
:目标 #新闻:目标 选择当前活动的#新闻元素(点击包含该锚点名称的URL)
:有效 input:有效 选择所有具有有效值的<input>元素
:已访问 a:已访问 选择所有已访问的链接

所有CSS伪元素

选择器 示例 示例说明
::之后 p::之后 在每个<p>元素之后插入内容
::之前 p::之前 在每个<p>元素之前插入内容
::第一个字母 p::第一个字母 选择每个<p>元素的第一个字母
::第一行 p::第一行 选择每个<p>元素的第一行
::标记 ::标记 选择列表项的标记
::选择 p::选择 选择用户选择的元素部分

×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2024 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.