- CSS 菜鸟教程
- CSS - 教程
- CSS - 简介
- CSS - 语法
- CSS - 选择器
- CSS - 包含
- CSS - 度量单位
- CSS - 颜色
- CSS - 背景
- CSS - 字体
- CSS - 文本
- CSS - 图像
- CSS - 链接
- CSS - 表格
- CSS - 边框
- CSS - border-block 属性
- CSS - 边框内联
- CSS - 边距
- CSS - 列表
- CSS - Padding 属性
- CSS - 光标
- CSS - 轮廓
- CSS - 维度
- CSS - 滚动条
- CSS - 内联块
- CSS - 下拉列表
- CSS - visibility 属性
- CSS - Overflow 属性
- CSS - 清除修复
- CSS - float(浮点)
- CSS - 箭头
- CSS - resize 属性
- CSS - quotes 属性
- CSS - order 属性
- CSS - Position 属性
- CSS - hypens 属性
- CSS - :hover(悬停)
- CSS - display(显示)
- CSS - focus 属性
- CSS - zoom(缩放)
- CSS - translate 属性
- CSS - Height 属性
- CSS - hyphenate-character 属性
- CSS - Width 属性
- CSS - opacity 属性
- CSS - z-index 属性
- CSS - bottom 属性
- CSS - 导航栏
- CSS - 覆盖
- CSS - 表单
- CSS - 对齐
- CSS - 图标
- CSS - 图片库
- CSS - 注释
- CSS - 加载器
- CSS - Atrribute 选择器属性
- CSS - 运算器
- CSS - root
- CSS - 盒子模型
- CSS - 计数器
- CSS - Clip (Obsolete) 属性
- CSS - writing-mode 属性
- CSS - Unicode-bidi 属性
- CSS - min-content 属性
- CSS - 全部
- CSS - inset 属性
- CSS - isolation 属性
- CSS - overscroll-behavior 属性
- CSS - justify-items 属性
- CSS - justify-self 属性
- CSS - tab-size 属性
- CSS - pointer-event 属性
- CSS - place-content 属性
- CSS - place-items 属性
- CSS - place-self 属性
- CSS - max-block-size 属性
- CSS - min-block-size 属性
- CSS - mix-blend-mode 属性
- CSS - max-inline-size 属性
- CSS - min-inline-size 属性
- CSS - offset 属性
- CSS - accent-color 属性
- CSS - user-select 属性
- CSS 高级
- CSS - grid 属性
- CSS - Grid 布局
- CSS - flexbox
- CSS - vertical-align 属性
- css - positioning
- css - layers
- css - pseudo_classes
- CSS - 伪元素
- CSS - @ 规则
- CSS 滤镜 - text-effect 属性
- CSS 分页媒体
- CSS 打印
- CSS - 布局
- CSS - 验证
- CSS - 图像精灵
- CSS - !important
- CSS - 数据类型
- CSS3 教程
- CSS - 圆角
- CSS - 边框图像
- CSS - 多种背景
- CSS - 渐变
- CSS - box-shadow 属性
- CSS - box-decoration-break 属性
- CSS - caret-color 属性
- CSS - text-shadow 属性
- CSS - 2D 转换
- CSS - 3D 变换
- CSS - transition 属性
- CSS - 动画
- CSS - 多列布局
- CSS - 盒子大小调整
- CSS - 工具提示
- CSS - buttons
- CSS - 分页
- CSS - 变量
- CSS - 媒体查询
- CSS - 值函数
- CSS - 数学函数
- CSS - Mask 属性
- CSS - shape-outside 属性
- CSS - 样式图像
- CSS - 特异性
- CSS - 自定义属性
- CSS 响应式
- CSS - 响应式网页设计 (RWD)
- CSS - 响应式设计视口
- CSS - 响应式网格视图
- CSS - 响应式媒体查询
- CSS - 响应式图像
- CSS - 响应式视频
- CSS - 响应式框架
- CSS 引用
- CSS - 所有属性列表
- CSS - 颜色引用
- CSS - 浏览器支持参考
- CSS - 网页字体
- CSS 工具
- CSS - PX 到 EM 的转换
css - pseudo_classes
CSS 中的伪类用于根据元素在文档树中的状态或位置来选择元素并设置其样式,而无需添加额外的类或 JavaScript。
例如,当鼠标悬停在元素上时,伪类可用于更改元素的颜色,或者单击按钮以更改颜色。
什么是伪类?
- 伪类通常与 CSS 选择器一起使用,通过在选择器后插入冒号 (:)。例如 a : hover{},这里的选择器 'a' 将选择文档中的所有锚标签。
- 函数式伪类包含一对括号来定义参数。例如:lang(en)。
- 伪类附加到的元素称为锚点元素。例如:button:hover、a:focus等。这里按钮和一个元素被称为锚元素。
- 伪类根据文档树的内容将样式应用于元素。
- 伪类还会根据外部因素对元素应用样式,例如元素的导航历史记录 (:visited)、内容的状态 (:checked) 或鼠标位置 (:hover)
语法
selector:pseudo-class {
property: value;
}
伪类悬停
在 CSS 中,伪类 :hover 用于指定元素的鼠标悬停状态。这用于在用户鼠标穿过文档中的元素时设置元素的样式。
语法
tag:hover {
property: value;
}
以下示例演示如何应用此功能。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
a{
background-color: lightgrey;
padding: 10px;
}
a:hover {
color: red;
}
div{
padding: 10px;
border: solid 3px;
background-color: aqua;
}
div:hover{
background-color: lightgreen;
}
</style>
</head>
<body>
<h3>Anchor Tag Hovering</h3>
<a href="#">Hover over me!</a>
<h3>Div Hovering</h3>
<div>Hover me</div>
</body>
</html>
伪类活动
当用户通过单击或点击元素来激活元素时,伪类 :active 将向元素应用样式。这最常用于交互式元素,如按钮和锚标记,但所有 HTML 元素都可以使用此伪类。
语法
tag:active {
property: value;
}
下面是一个示例,显示了伪类 active 的不同用法。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
a, p, li {
color: black;
background-color: lightgrey;
padding: 7px;
border: 3px solid;
}
a:active {
color: red;
}
p:active {
background-color: gold;
}
li:active {
background-color: darkred;
}
</style>
</head>
<body>
<h2>Active Pseudo-Class Example</h2>
<h3>For Button:</h3>
<a href="#">Click Me</a>
<h3>For paragraph:</h3>
<p>Click me to see the effect.</p>
<h3>For list:</h3>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</body>
</html>
伪类焦点
当用户通过单击输入标签等元素来聚焦元素时,伪类 :focus 将把样式应用于元素。在输入元素中输入文本之前,用户必须单击输入区域以启用光标,这称为聚焦。
语法
tag:focus {
property: value;
}
此示例将展示如何在 HTML 中使用伪类焦点。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
input{
padding:3px;
}
input:focus {
border-color: green;
background-color: lightgrey;
}
</style>
</head>
<body>
<h2>Pseudo-Class focus Example</h2>
<h3>Focus on input text</h3>
<input type="text"
placeholder="Type Something!">
</body>
</html>
伪类第 n 个子
伪类 :nth-child(n) 将把样式应用于元素的任何指定的直接子元素。
语法
tag:nth-child(number/ expression / odd / even) {
property: value;
}
伪类第 n 个子类可以将数字、数学表达式或像奇数这样的值(偶数)作为参数。要了解与第 n 个子项关联的值,请访问我们关于伪类 nth-child() 的教程。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
div{
border: 2px solid;
margin: 7px;
padding: 2px;
}
/* Apply Style to 2nd child of div */
div:nth-child(2){
background-color:red;
}
/* Apply Style to all odd children of li */
li:nth-child(odd) {
background-color: lightgray;
}
/* Apply Style to all even children of li */
li:nth-child(even) {
background-color: lightblue;
}
</style>
</head>
<body>
<h2>Pseudo-Class nth-child</h2>
<h3>2nd child of Div</h3>
<div>
<div>1st div</div>
<div>2nd div</div>
<div>3rd div</div>
<div>4th div</div>
</div>
<h3>Selecting odd and even children</h3>
<ul>
<li>First item</li>
<li>Second item</li>
<li>Third item</li>
<li>forth item</li>
<li>Third item</li>
<li>fifth item</li>
</ul>
</body>
</html>
伪阶级长子
用于选择第一个直接子元素的伪类 first-child。
语法
tag:first-child {
property: value;
}
以下示例演示如何在 HTML 中使用第一个子伪类。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
div{
border: solid;
}
/* Selects all first child paragraphs */
p:first-child {
color: blue;
}
</style>
</head>
<body>
<p>
This paragraph is first child of body
element, will be blue.
</p>
<p>This paragraph will not be affected.</p>
<p>Another paragraph that won't be affected.</p>
<div>
<p>
This paragraph is first child of div
element will be blue.
</p>
<p>This paragraph will not be affected.</p>
<p>Another paragraph that won't be affected.</p>
</div>
</body>
</html>
伪类 Last-Child
伪类 last-child,用于选择最后一个直接子元素。
语法
tag:last-child {
property: value;
}
以下示例演示如何在 HTML 中使用最后一个子伪类。
<!DOCTYPE html>
<html lang="en">
<head>
<style>
div{
border: solid;
}
/* Selects all last child paragraphs */
p:last-child {
color: blue;
}
</style>
</head>
<body>
<p>This paragraph will not be affected.</p>
<p>Another paragraph that won't be affected.</p>
<div>
<p>This paragraph will not be affected.</p>
<p>Another paragraph that won't be affected.</p>
<p>
This paragraph is last child of div
element will be blue.
</p>
</div>
<p>
This paragraph is last child of body
element, will be blue.
</p>
</body>
</html>
伪类郎
伪类 :lang() 将根据设置为元素或其父元素的 lang 属性的值将样式应用于元素。
下面是 :lang() 伪类的一个例子:
<html>
<head>
<style>
/* Selects all the tags that set english as language */
:lang(en) {
quotes: '""';
}
/* Selects all the tags that set french as language */
:lang(fr) {
quotes: '« ' ' »';
}
</style>
</head>
<body>
<h2>:lang() selector example</h2>
<q lang="en">
This language is set as english, Here
css use double(" ") quotes
</q>
<br>
<q lang="fr">
This language is set as French, Here
css use guillemet(« ») quotes
</q>
</body>
</html>
伪类 不是
伪类 :not(selector) 用于将样式应用于上述选择器中包含的所有元素期望元素。要了解什么是CSS中的选择器,请查看我们的 CSS 选择器 教程。
语法
tag:not(selector){
property: value;
}
选择器可以是 html 中的类、id 或标签。
例以下示例显示了如何在 CSS 中使用 not pseudo-class
<!DOCTYPE html>
<html lang="en">
<head>
<title>CSS :not() Example</title>
<style>
/*Style all paragraph except class special*/
p:not(.special) {
color: red;
}
/*Style all special paragraph except id superSpecial*/
.special:not(#superSpecial){
background-color: lightgrey;
}
</style>
</head>
<body>
<p>This is a normal paragraph.</p>
<p class="special" id="superSpecial">
This is a super special paragraph.
</p>
<p>This is another normal paragraph.</p>
<p class="special">
This is special paragraph.
</p>
</body>
</html>
CSS 伪类列表
下表列出了所有 CSS 伪类:
伪类 | 描述 |
---|---|
:active | 表示用户已激活的元素。 |
:any-link | 表示一个元素,该元素充当超链接的源锚点,与是否已被访问过无关。 |
:autofill | 匹配浏览器具有其值 autofill 的元素。 |
:checked | 匹配选中或切换的任何单选按钮、复选框或选项元素。 |
:default | 选择一组相关元素中默认的表单元素。 |
:defined | 表示已定义的任何自定义元素。 |
:disabled | 表示已禁用的元素。 |
:empty | 匹配没有子元素的元素。 |
:enabled | 表示已启用的元素,该元素在被激活后。 |
:first | 表示打印文档的第一页,其中 @page 为规则。 |
:first-child | 表示一组同级元素中的第一个元素。 |
:first-of-type | 表示一组同级元素中其类型的第一个元素。 |
:fullscreen | 匹配当前以全屏模式显示的元素。 |
:focus | 表示已获得焦点的元素。 |
:focus-visible | 当元素与 :focus 伪类匹配或接收焦点时应用。 |
:focus-within | 如果元素或其任何后代聚焦元素,则匹配该元素。 |
:has() | 如果有任何相对选择器,则表示一个元素。 |
:host | 这将选择包含在其内部使用的 CSS 的影子 DOM 的影子主机。 |
:host() | 此函数选择包含在其内部使用的 CSS 的影子 DOM 的影子主机。 |
:host-context() | 此函数允许您根据其祖先元素的类或属性设置自定义元素的样式。 |
:hover | 当用户使用定点设备(如鼠标)与元素交互时匹配,但不一定激活它。 |
:indeterminate | 表示其状态不确定或未知的任何表单元素。 |
:in-range | 表示其当前值在范围限制内的元素 |
:invalid | 表示其内容无法验证的任何元素。 |
:is() | 将选择器列表作为其参数,并选择可由该列表中的一个选择器选择的任何元素。 |
:lang() | 根据元素被定义为使用的语言匹配元素。 |
:last-child | 表示一组同级元素中的最后一个元素。 |
:last-of-type | 表示一组同级元素中其类型的最后一个元素。 |
:left | 表示打印文档的所有左侧页面,与 @page at-rule 一起使用。 |
:link | 表示尚未访问过的元素。 |
:modal | 匹配处于某种状态的元素,在这种状态下,它排除与其外部元素的所有交互,直到交互被消除。 |
:not() | 表示与选择器列表不匹配的元素。 |
:nth-child() | 根据子元素在父元素内的所有同级元素中的位置选择子元素。 |
:nth-last-child() | 根据元素在兄弟姐妹中的位置匹配元素,从最后一个(结束)开始计算 |
:nth-last-of-type() | 根据元素在相同类型的同级中的位置匹配元素,从最后一个(结束)开始计算。 |
:nth-of-type() | 根据元素在相同类型的同级元素中的位置来匹配元素。 |
:only-child | 表示没有任何同级元素的元素。 |
:only-of-type | 表示没有相同类型的同级元素。 |
:optional | 表示未设置必需属性的元素。 |
:out-of-range | 表示其当前值超出范围限制的元素。 |
:picture-in-picture | 匹配当前处于画中画模式的元素。 |
:placeholder-shown | 表示当前正在显示占位符文本的任何元素。 |
:read-only | 表示用户不可编辑的元素。 |
:read-write | 表示用户可编辑的元素。 |
:required | 表示一个元素,该元素上设置了必需属性。 |
:right | 表示打印文档的所有右侧页面,与 @page at-rule 一起使用。 |
:root | 匹配文档树的根元素。 |
:scope | 表示作为选择器要匹配的参考点或范围的元素。 |
:target | 表示 ID 与 URL 的片段匹配的目标元素。 |
:valid | 表示其内容成功验证的任何元素。 |
:visited | 一旦访问了链接,就适用。 |
:where() | 将选择器列表作为其参数,并选择任何匹配的元素。 |