奇信邦网游福利站

CSS 史上最全面的选择器大全以及兼容性整理(共计 118 个)

CSS 史上最全面的选择器大全以及兼容性整理(共计 118 个)

CSS 选择器是 CSS 的核心工具,用于选择 HTML 元素并应用样式。它们就像网页中的“精准定位器”,可以根据元素的类型、属性、状态或位置进行选择。随着 web 技术的发展,CSS 选择器不断扩展,提供了更强大的功能。本文档整理了截至 2025 年的所有 CSS 选择器,共计118个,旨在为初学者和资深开发者提供全面、易懂的指南。

本文包含:

基本选择器:6 个组合器:6 个嵌套选择器:1 个属性选择器:9 个伪类选择器:71 个伪元素选择器:25 个使用 Can I Use 验证浏览器支持,尝试组合选择器实现复杂样式。

1. 基本选择器

类型选择器 (Type Selector)

描述: 选择特定类型的 HTML 元素(如

)。示例:p {

color: red;

}

这是一个段落。

效果: 所有

元素的文本颜色变为红色。兼容性: 所有现代浏览器(如 Chrome、Firefox、Safari、Edge)支持。

通用选择器 (Universal Selector)

描述: 使用 * 选择页面中的所有元素,常用于全局样式重置。示例:* {

margin: 0;

padding: 0;

}

内容

段落

效果: 所有元素的外边距和内边距重置为 0。兼容性: 所有现代浏览器支持,但需谨慎使用以避免性能问题。

类选择器 (Class Selector)

描述: 使用 . 前缀选择具有特定 class 属性的元素。示例:.highlight {

background-color: yellow;

}

高亮文本

效果: 具有 class="highlight" 的元素背景色变为黄色。兼容性: 所有现代浏览器支持。

ID 选择器 (ID Selector)

描述: 使用 # 前缀选择具有特定 id 属性的唯一元素。示例:#main {

width: 100%;

}

主要内容

效果: ID 为 main 的元素宽度设置为 100%。兼容性: 所有现代浏览器支持,ID 应在页面中唯一。

交集选择器 (Compound Selector)

描述: 同时满足多个条件的元素(连续书写无空格)。示例:p.highlight {

border: 2px solid gold;

}

高亮段落

不匹配

效果: 同时是

标签且具有 highlight 类的元素添加金色边框。兼容性: CSS 的基础功能,所有浏览器均支持。兼容性取决于交集中使用的最新选择器或伪类。

并集选择器 (Multiple Selector)

描述: 使用逗号分隔多个选择器,选择满足任一条件的元素。示例:h1, h2, .title {

font-weight: bold;

}

标题1

标题2

标题段落

效果: 所有

和具有 title 类的元素字体加粗。兼容性: 所有浏览器均支持。

2. 组合器 (Combinators)

后代选择器 (Descendant Combinator)

描述: 使用空格选择某个元素内的所有后代元素。

示例:

div p {

color: blue;

}

这是一个段落。

嵌套段落

效果:

内的所有

元素文本颜色变为蓝色。

兼容性: 所有现代浏览器支持。

子选择器 (Child Combinator)

描述: 使用 > 选择某个元素的直接子元素。示例:div > p {

color: green;

}

直接子段落

非直接子段落

效果: 仅

的直接子

元素文本颜色变为绿色。兼容性: 所有现代浏览器支持。

相邻同胞选择器 (Adjacent Sibling Combinator)

描述: 使用 + 选择紧跟在某个元素后的同胞元素。示例:h1 + p {

font-size: 18px;

}

标题

紧邻段落

非紧邻段落

效果: 紧跟

后的第一个

字体大小为 18px。兼容性: 所有现代浏览器支持。

一般同胞选择器 (General Sibling Combinator)

描述: 使用 ~ 选择某个元素之后的所有同胞元素。示例:h1 ~ p {

margin-left: 20px;

}

标题

段落1

段落2

效果:

后的所有

元素左边距为 20px。兼容性: 所有现代浏览器支持。

列组合器 (Column Combinator)

描述: 使用 || 选择表格中同一列的元素。

示例:

col || td {

border: 1px solid black;

}

单元格

效果: 同一列中的 元素添加边框。

兼容性: 这是一项实验性技术 #selectordef-column,大部分浏览器不支持。

命名空间分隔符 (Namespace Separator)

描述: 使用 | 选择特定命名空间的元素(如 SVG)。示例:SVG|a {

fill: red;

}

SVG 链接

效果: SVG 命名空间中的 元素填充颜色为红色。兼容性: 所有现代浏览器支持。

3. 嵌套选择器 (Nesting Selector)

&

描述: 用于 CSS 原生嵌套语法,表示当前选择器的父选择器,可简化选择器层级。(类似Sass以及Less的嵌套语法)

示例:

.parent {

color: black;

& .child {

color: blue;

}

}

子元素

效果: .parent 内的 .child 元素文本颜色为蓝色,等同于 .parent .child。

兼容性: 支持有限,大部分浏览器仅在2023年后的版本支持

4. 属性选择器 (Attribute Selectors)

[attr]

描述: 选择具有特定属性的元素。

示例:

a[href] {

color: blue;

}

链接

效果: 具有 href 属性的 元素颜色为蓝色。

兼容性: CSS 2.1选择器,所有现代浏览器支持。

[attr=value]

描述: 选择属性值等于特定值的元素。示例:input[type="text"] {

background: yellow;

}

效果: 类型为 text 的 背景色为黄色。兼容性: CSS 2.1选择器,所有现代浏览器支持。

[attr~=value]

描述: 选择属性值包含特定单词的元素(空格分隔)。示例:p[title~="flower"] {

font-style: italic;

}

文本

效果: title 属性包含单词 flower 的

元素为斜体。兼容性: CSS 2.1选择器,所有现代浏览器支持。

[attr|=value]

描述: 选择属性值为特定值或以特定值开头的元素(用于语言子码)。示例:[lang|="en"] {

color: green;

}

文本

效果: lang 属性以 en 开头的元素颜色为绿色。兼容性: CSS 2.1选择器,所有现代浏览器支持。

[attr^=value]

描述: 选择属性值以特定值开头的元素。示例:a[href^="https"] {

color: purple;

}

链接

效果: href 属性以 https 开头的 元素颜色为紫色。兼容性: CSS 3选择器,所有现代浏览器支持。

[attr$=value]

描述: 选择属性值以特定值结尾的元素。示例:a[href$=".pdf"] {

background: yellow;

}

文档

效果: href 属性以 .pdf 结尾的 元素背景色为黄色。兼容性: CSS 3选择器,所有现代浏览器支持。

[attr*=value]

描述: 选择属性值包含特定值的元素。示例:a[href*="example"] {

text-decoration: underline;

}

链接

效果: href 属性包含 example 的 元素添加下划线。兼容性: CSS 3选择器,所有现代浏览器支持。

[attr=value i]

描述: 选择属性值等于特定值(忽略大小写)的元素。示例:a[href="https://example.com" i] {

color: green;

}

链接

效果: href 属性忽略大小写匹配 https://example.com 的 元素颜色为绿色。兼容性: 除了IE浏览器,其他所有现代浏览器支持。

[attr=value s]

描述: 选择属性值严格等于特定值的元素(区分大小写)。示例:a[href="https://example.com" s] {

color: red;

}

链接

效果: href 属性严格匹配 https://example.com 的 元素颜色为红色。兼容性: 仅火狐浏览器支持。

5. 伪类选择器 (Pseudo-classes)

伪类选择器用于选择元素的特定状态或位置,按功能分组如下:

交互伪类

:hover

描述: 鼠标悬停在元素上时。示例:a:hover {

color: red;

}

链接

效果: 鼠标悬停时链接颜色变为红色。兼容性: 所有现代浏览器支持。

:active

描述: 元素被激活(如点击)时。

示例:

button:active {

background: darkblue;

}

效果: 点击按钮时背景色变为深蓝色。

兼容性: 所有现代浏览器支持。

:focus

描述: 元素获得焦点时。

示例:

input:focus {

outline: none;

}

效果: 输入框获得焦点时移除默认轮廓。

兼容性: 所有现代浏览器支持。

:focus-within

描述: 元素或其后代获得焦点时。

示例:

form:focus-within {

border: 2px solid blue;

}

效果: 表单或其输入框获得焦点时,边框变为蓝色。

兼容性: 除了IE浏览器,大多数现代浏览器支持。

:focus-visible

描述: 元素通过键盘导航获得焦点时。

示例:

a:focus-visible {

outline: 2px solid red;

}

链接

效果: 通过键盘导航获得焦点时显示红色轮廓。

兼容性: 除了IE浏览器,大多数现代浏览器支持。

:link

描述: 未访问的链接。示例:a:link {

color: blue;

}

链接

效果: 未访问链接颜色为蓝色。兼容性: 所有现代浏览器支持。

:visited

描述: 已访问的链接。

示例:

a:visited {

color: purple;

}

链接

效果: 已访问链接颜色为紫色。

兼容性: 所有现代浏览器支持,样式受隐私限制。

:any-link

描述: 未访问或已访问的链接。

示例:

a:any-link {

text-decoration: underline;

}

链接

效果: 所有链接添加下划线。

兼容性: 除了IE浏览器,大多数现代浏览器支持。

结构伪类

:first-child

描述: 父元素的第一个子元素。

示例:

p:first-child {

margin-top: 0;

}

第一个

第二个

效果: 第一个

上边距为 0。

兼容性: 所有现代浏览器支持。

:last-child

描述: 父元素的最后一个子元素。

示例:

p:last-child {

margin-bottom: 0;

}

第一个

最后一个

效果: 最后一个

下边距为 0。

兼容性: 所有现代浏览器支持。

:nth-child(n)

描述: 父元素的第 n 个子元素。

示例:

li:nth-child(2) {

color: red;

}

  • 1
  • 2

效果: 第二个

  • 颜色变为红色。

    兼容性: 所有现代浏览器支持。

    :nth-last-child(n)

    描述: 从末尾计数的第 n 个子元素。

    示例:

    li:nth-last-child(2) {

    color: red;

    }

    • 1
    • 2
    • 3

    效果: 倒数第二个

  • 颜色变为红色。

    兼容性: 所有现代浏览器支持。

    :first-of-type

    描述: 父元素的第一个同类型子元素。

    示例:

    p:first-of-type {

    font-weight: bold;

    }

    其他

    第一个

    效果: 第一个

    字重加粗。

    兼容性: 所有现代浏览器支持。

    :last-of-type

    描述: 父元素的最后一个同类型子元素。

    示例:

    p:last-of-type {

    text-decoration: underline;

    }

    第一个

    最后一个

    效果: 最后一个

    添加下划线。

    兼容性: 所有现代浏览器支持。

    :nth-of-type(n)

    描述: 父元素的第 n 个同类型子元素。示例:p:nth-of-type(2) {

    color: green;

    }

    1

    2

    3

    效果: 第二个

    颜色变为绿色。兼容性: 所有现代浏览器支持。

    :nth-last-of-type(n)

    描述: 从末尾计数的第 n 个同类型子元素。

    示例:

    p:nth-last-of-type(1) {

    font-weight: bold;

    }

    1

    2

    3

    效果: 最后一个

    字重加粗。

    兼容性: 所有现代浏览器支持。

    :only-child

    描述: 父元素的唯一子元素。

    示例:

    p:only-child {

    background: yellow;

    }

    唯一

    效果: 如果

    是唯一子元素,背景色为黄色。

    兼容性: 所有现代浏览器支持。

    :only-of-type

    描述: 父元素中唯一的一个同类型子元素。

    示例:

    p:only-of-type {

    font-size: 20px;

    }

    唯一

    其他

    效果: 如果

    是唯一

    ,字体大小为 20px。

    兼容性: 所有现代浏览器支持。

    :empty

    描述: 没有子元素或文本的元素。

    示例:

    div:empty {

    height: 50px;

    background: grey;

    }

    效果: 空的

    高度为 50px,背景色为灰色。

    兼容性: 所有现代浏览器支持。

    状态伪类

    :checked

    描述: 选中的表单元素。

    示例:

    input[type="checkbox"]:checked {

    accent-color: green;

    }

    效果: 选中的复选框颜色变为绿色。

    兼容性: 所有现代浏览器支持。(在 macOS 系统上,对

    :disabled

    描述: 禁用的表单元素。

    示例:

    input:disabled {

    background: grey;

    }

    效果: 禁用的输入框背景色为灰色。

    兼容性: 所有现代浏览器支持。

    :enabled

    描述: 启用的表单元素。

    示例:

    input:enabled {

    background: white;

    }

    效果: 启用的输入框背景色为白色。

    兼容性: 所有现代浏览器支持。

    :default

    描述: 默认选中的表单元素。

    示例:

    input:default {

    outline: 2px solid green;

    }

    效果: 默认选中的单选框添加绿色轮廓。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    :indeterminate

    描述: 不确定状态的表单元素。

    示例:

    input:indeterminate {

    outline: 2px solid orange;

    }

    效果: 不确定状态的复选框添加橙色轮廓。

    兼容性: 大部分现代浏览器支持。

    :valid

    描述: 输入合法的表单元素。

    示例:

    input:valid {

    border: 1px solid green;

    }

    效果: 输入合法的邮箱字段添加绿色边框。

    兼容性: 所有现代浏览器支持。

    :invalid

    描述: 输入不合法的表单元素。

    示例:

    input:invalid {

    border: 1px solid red;

    }

    效果: 输入不合法的邮箱字段添加红色边框。

    兼容性: 所有现代浏览器支持。

    :in-range

    描述: 值在范围内的表单元素。

    示例:

    input:in-range {

    background: white;

    }

    效果: 值在范围内的输入框背景色为白色。

    兼容性: 大部分现代浏览器支持。

    :out-of-range

    描述: 值不在范围内的表单元素。

    示例:

    input:out-of-range {

    background: pink;

    }

    效果: 值不在范围内的输入框背景色为粉色。

    兼容性: 大部分现代浏览器支持。

    :required

    描述: 必填的表单元素。

    示例:

    input:required {

    border: 1px solid red;

    }

    效果: 必填输入框添加红色边框。

    兼容性: 所有现代浏览器支持。

    :optional

    描述: 非必填的表单元素。

    示例:

    input:optional {

    border: 1px solid grey;

    }

    效果: 非必填输入框添加灰色边框。

    兼容性: 所有现代浏览器支持。

    :read-only

    描述: 只读的表单元素。

    示例:

    input:read-only {

    background: lightgrey;

    }

    效果: 只读输入框背景色为浅灰色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    :read-write

    描述: 可编辑的表单元素。

    示例:

    input:read-write {

    background: white;

    }

    效果: 可编辑输入框背景色为白色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    :placeholder-shown

    描述: 显示占位符的输入框。

    示例:

    input:placeholder-shown {

    color: grey;

    }

    效果: 显示占位符的输入框文本颜色为灰色。

    兼容性: 大部分现代浏览器支持。

    :autofill

    描述: 浏览器自动填充的输入框。

    示例:

    input:autofill {

    background: lightyellow;

    }

    效果: 自动填充的输入框背景色为浅黄色。

    兼容性: 除了IE浏览器,大多数现代浏览器支持。

    :user-valid

    描述: 用户交互后合法的表单元素。

    示例:

    input:user-valid {

    border: 1px solid green;

    }

    效果: 用户交互后合法的输入框添加绿色边框。

    兼容性: 2023年后现代浏览器支持,支持有限。Chrome 119+版本支持,

    :user-invalid

    描述: 用户交互后不合法的表单元素。

    示例:

    input:user-invalid {

    border: 1px solid red;

    }

    效果: 用户交互后不合法的输入框添加红色边框。

    兼容性: 2023年后现代浏览器支持,支持有限。Chrome 119+版本支持,

    :blank

    描述: 空值的用户输入元素。示例:input:blank {

    border: 1px solid yellow;

    }

    效果: 空值的输入框添加黄色边框。兼容性: 这是一项实验性技术 #blank-pseudo,大部分浏览器不支持。

    逻辑伪类

    :not(selector)

    描述: 不匹配指定选择器的元素。

    示例:

    div:not(.highlight) {

    background: white;

    }

    普通
    高亮

    效果: 不具有 highlight 类的

    背景色为白色。

    兼容性: 所有现代浏览器支持。

    :not(a, .b, [c])

    描述: 匹配不同时满足列表中任何一个选择器的元素(即不匹配 a 标签、不匹配类名为 .b、不匹配带有属性 [c] 的元素)。示例:

    /* 选择非链接(a)、非警告类(.warning)、非禁用状态([disabled])的按钮 */

    button:not(a, .warning, [disabled]) {

    background-color: #4CAF50; /* 绿色背景 */

    cursor: pointer;

    }

    /* 为被排除的元素添加对比样式(仅用于演示) */

    button:a, button.warning, button[disabled] {

    background-color: #f44336; /* 红色背景 */

    cursor: not-allowed;

    }

    链接按钮

    效果: 仅 应用绿色背景(因不匹配 a、.warning、[disabled] 中的任何一个)。

    兼容性: 2021年后大部分现代浏览器支持,支持有限。Chrome 88+版本以上支持。(可使用链式 :not() 替代)

    :is(selector1, selector2)

    描述: 匹配任一指定选择器的元素。

    示例:

    button:is(:hover, :focus) {

    background-color: yellow;

    }

    效果: 按钮悬停或获得焦点时,背景色为黄色。

    兼容性: 除了IE浏览器,大多数现代浏览器支持。

    :where(selector1, selector2)

    描述: 类似 :is(),但不增加特异性。

    示例:

    :where(h1, h2, h3) {

    font-weight: bold;

    }

    标题1

    标题2

    效果: h1、h2、h3 字重加粗。

    兼容性: 除了IE浏览器,大多数现代浏览器支持。

    :has(selector)

    描述: 包含指定选择器子元素的元素。

    示例:

    div:has(p) {

    border: 1px solid black;

    }

    内容

    效果: 包含

    添加边框。

    兼容性: 2022年后大部分现代浏览器支持,支持有限,Chrome 105+版本以上支持。

    其他伪类

    :root

    描述: 文档的根元素(通常为 )。

    示例:

    :root {

    --main-color: #3498db;

    }

    内容

    效果: 定义全局 CSS 变量。

    兼容性: 所有现代浏览器支持。

    :lang(language)

    描述: 根据 lang 属性选择元素。

    示例:

    p:lang(en) {

    color: blue;

    }

    English

    效果: lang="en" 的段落颜色为蓝色。

    兼容性: 所有现代浏览器支持。

    :target

    描述: URL 片段标识的目标元素。

    示例:

    :target {

    background: yellow;

    }

    目标

    效果: 当 URL 为 #section1 时,背景色为黄色。

    兼容性: 所有现代浏览器支持。

    :target-within

    描述: 目标元素或包含目标元素的元素。示例:div:target-within {

    border: 1px solid blue;

    }

    目标

    效果: 包含目标元素的

    添加蓝色边框。兼容性: 这是一项实验性技术 #target-within-pseudo,大部分浏览器不支持。

    :scope

    描述: 作用域根元素。

    示例:

    :scope {

    background: lightgrey;

    }

    内容

    效果: 作用域根元素背景色为浅灰色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    :current

    描述: 时间维度画布中当前显示的元素。示例:p:current {

    color: red;

    }

    当前

    效果: 当前显示的元素颜色为红色。兼容性: 这是一项实验性技术 #the-current-pseudo,大部分浏览器不支持。

    :past

    描述: 时间维度画布中过去的元素。

    示例:

    p:past {

    opacity: 0.5;

    }

    过去

    效果: 过去的元素透明度为 0.5。

    兼容性: 支持有限。IE浏览器以及火狐浏览器所有版本均不支持,Edge浏览器仅在2020年后的版本支持。

    :future

    描述: 时间维度画布中未来的元素。

    示例:

    p:future {

    opacity: 0.5;

    }

    未来

    效果: 未来的元素透明度为 0.5。

    兼容性: 支持有限。IE浏览器以及火狐浏览器所有版本均不支持,Edge浏览器仅在2020年后的版本支持。

    :dir(ltr)

    描述: 左到右方向的元素。

    示例:

    p:dir(ltr) {

    text-align: left;

    }

    文本

    效果: 左到右方向的元素左对齐。

    兼容性: 支持有限。 2023年后的大部分现代浏览器支持。 火狐浏览器可支持2012年后的版本,需添加-moz-前缀。

    :modal

    描述: 模态对话框元素。

    示例:

    dialog:modal {

    background: white;

    }

    对话框

    效果: 模态对话框背景色为白色。

    兼容性: 支持有限,仅2022年后大部分浏览器支持。Chrome 105+以上版本支持。

    :fullscreen

    描述: 全屏模式的元素。

    示例:

    video:fullscreen {

    border: none;

    }

    效果: 全屏模式的视频移除边框。

    兼容性: 支持有限,早期版本需添加-webkit- 以及-moz-前缀。

    :picture-in-picture

    描述: 画中画模式的元素。

    示例:

    video:picture-in-picture {

    border: 1px solid black;

    }

    效果: 画中画模式的视频添加黑色边框。

    兼容性: 支持有限,仅2023年后大部分现代浏览器支持,Chrome 110+以上版本支持,火狐浏览器以及IE浏览器所有版本均不支持。

    :popover-open

    描述: 当前显示的弹出窗口元素。

    示例:

    :popover-open {

    display: block;

    }

    弹出

    效果: 打开的弹出窗口显示为块级元素。

    兼容性: 支持有限,仅2023年后大部分现代浏览器支持,Chrome 114+以上版本支持。

    :host

    描述: 匹配 Shadow DOM 中所有 shadow root 的根元素,可加括号后接选择器,匹配符合条件的根元素。

    示例:

    :host(.active) {

    background: blue;

    }

    内容

    效果: 具有 active 类的 shadow root 根元素背景色为蓝色。

    兼容性: 除了IE浏览器,大多数现代浏览器支持。(2020年以前的Edge浏览器不支持)

    :host-context(selector)

    描述: 匹配 Shadow DOM 中符合指定选择器条件的元素。

    示例:

    :host-context(.dark-theme) {

    color: white;

    }

    内容

    效果: 当父元素具有 dark-theme 类时,Shadow DOM 根元素文本颜色为白色。

    兼容性: 支持有限,苹果浏览器、火狐浏览器以及IE浏览器所有版本均不支持,Edge浏览器仅支持2020年后的版本

    :left

    描述: 与 @page 规则一起使用,选择打印文档的所有左侧页面。

    示例:

    @page :left {

    margin-left: 4cm;

    }

    打印内容

    效果: 打印文档的左侧页面左边距为 4cm。

    兼容性: 大部分现代浏览器支持,火狐浏览器所有版本均不支持。

    :right

    描述: 与 @page 规则一起使用,选择打印文档的所有右侧页面。

    示例:

    @page :right {

    margin-right: 4cm;

    }

    打印内容

    效果: 打印文档的右侧页面右边距为 4cm。

    兼容性: 大部分现代浏览器支持,火狐浏览器所有版本均不支持。

    :state()

    描述: 选择具有指定自定义状态的自定义元素。

    示例:

    my-element:state(highlighted) {

    border: 2px solid yellow;

    }

    内容

    效果: 具有 highlighted 自定义状态的元素添加黄色边框。

    兼容性: 支持有限,需检查自定义元素支持情况,仅2024年后的部分现代浏览器支持。

    :open

    描述: 匹配处于打开状态的元素(如

    )。

    示例:

    details:open {

    background: lightblue;

    }

    摘要

    内容

    效果: 打开状态的

    元素背景色为浅蓝色。

    兼容性: 支持有限,部分浏览器仅2025年后的版本支持,Chrome 133+以上版本支持,safari浏览器以及Opera浏览器所有版本均不支持。

    :closed

    描述: 匹配处于关闭状态的元素(如

    )。示例:details:closed {

    background: lightgrey;

    }

    摘要

    内容

    效果: 关闭状态的

    元素背景色为浅灰色。兼容性: 截止本文发布(2025/06),所有浏览器均不支持。

    :muted

    描述: 匹配音频或视频元素处于静音状态。

    示例:

    video:muted {

    border: 1px solid grey;

    }

    效果: 静音的视频元素添加灰色边框。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :paused

    描述: 匹配暂停状态的音频或视频元素。

    示例:

    video:paused {

    opacity: 0.7;

    }

    效果: 暂停的视频元素透明度为 0.7。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :playing

    描述: 匹配播放状态的音频或视频元素。

    示例:

    video:playing {

    border: 2px solid green;

    }

    效果: 播放中的视频元素添加绿色边框。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :seeking

    描述: 匹配音频或视频元素正在寻找(跳转)到新位置的状态。

    示例:

    video:seeking {

    border: 2px dashed blue;

    }

    效果: 正在跳转的视频元素添加蓝色虚线边框。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :buffering

    描述: 匹配音频或视频元素正在缓冲的状态。

    示例:

    video:buffering {

    background: lightyellow;

    }

    效果: 缓冲中的视频元素背景色为浅黄色。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :stalled

    描述: 匹配音频或视频元素因数据不足而暂停加载的状态。

    示例:

    video:stalled {

    border: 1px solid red;

    }

    效果: 因数据不足暂停的视频元素添加红色边框。

    兼容性: 支持有限,仅有Safari 15.4+以上版本浏览器支持。

    :xr-overlay

    描述: 匹配 XR(扩展现实)会话中的叠加层元素。

    示例:

    div:xr-overlay {

    background: rgba(0,0,0,0.5);

    }

    XR 内容

    效果: XR 叠加层元素背景为半透明黑色。

    兼容性: 支持有限,大部分浏览器仅2020年后的版本支持,Chrome 83+以上版本支持,Safari浏览器、火狐浏览器以及IE浏览器所有版本均不支持。

    6. 伪元素选择器 (Pseudo-elements)

    ::before

    描述: 在元素内容前插入内容。

    示例:

    p::before {

    content: "★ ";

    }

    文本

    效果: 段落前插入星号。

    兼容性: 所有现代浏览器支持。

    ::after

    描述: 在元素内容后插入内容。示例:p::after {

    content: " ★";

    }

    文本

    效果: 段落后插入星号。兼容性: 所有现代浏览器支持。

    ::first-line

    描述: 选择元素的第一行。

    示例:

    p::first-line {

    color: blue;

    }

    第一行
    第二行

    效果: 段落第一行颜色为蓝色。

    兼容性: 所有现代浏览器支持。

    ::first-line (SVG \ Support)

    描述: 选择 SVG 元素的第一行文本。示例:text::first-line {

    fill: blue;

    }

    第一行文本
    第二行文本

    效果: SVG 元素的第一行文本填充颜色为蓝色。兼容性: 支持有限,仅Firefox 124+以上版本支持。

    ::first-letter

    描述: 选择元素的第一个字母。

    示例:

    p::first-letter {

    color: red;

    }

    文本

    效果: 段落第一个字母颜色为红色。

    兼容性: 所有现代浏览器支持。

    ::first-letter (SVG \ Support)

    描述: 选择 SVG 元素的第一个字符。示例:text::first-letter {

    fill: red;

    font-size: 1.5em;

    }

    文本内容

    效果: SVG 元素的第一个字符填充颜色为红色,字体大小增大。兼容性: 支持有限,仅Firefox 124+以上版本支持。

    ::selection

    描述: 用户选中的文本。

    示例:

    ::selection {

    background: yellow;

    color: black;

    }

    选中文本

    效果: 选中文本背景色为黄色,文字为黑色。

    兼容性: 所有现代浏览器支持,Safari移动端所有版本均不支持

    ::placeholder

    描述: 输入框的占位符文本。

    示例:

    input::placeholder {

    color: #999;

    font-style: italic;

    }

    效果: 输入框占位符文本为灰色斜体。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    ::marker

    描述: 选择列表项的标记。

    示例:

    li::marker {

    color: red;

    }

    • 项目

    效果: 列表项标记颜色为红色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    ::backdrop

    描述: 选择对话框或全屏元素的背景。

    示例:

    dialog::backdrop {

    background: rgba(0,0,0,0.5);

    }

    对话框

    效果: 对话框背景半透明黑色。

    兼容性: 所有现代浏览器支持。

    ::cue

    描述: 选择媒体元素的字幕。

    示例:

    video::cue {

    color: white;

    }

    效果: 视频字幕颜色为白色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    ::part(name)

    描述: 匹配 shadow tree 中满足 part 条件的元素。

    示例:

    ::part(my-part) {

    background: blue;

    }

    内容

    效果: 指定 part 的元素背景色为蓝色。

    兼容性: 支持有限,大部分浏览器仅在2020年后的版本支持,Chrome 73+以上版本支持。

    ::file-selector-button

    描述: 选择文件上传按钮。

    示例:

    input::file-selector-button {

    background: green;

    }

    效果: 文件上传按钮背景色为绿色。

    兼容性: 所有现代浏览器支持,2021年之前大部分浏览器需使用非标准名称::-webkit-file-upload-button,IE浏览器10以及11版本需使用非标准名称::-ms-browse。

    ::slotted(selector)

    描述: 匹配模板中的插槽元素。

    示例:

    ::slotted(p) {

    color: red;

    }

    内容

    效果: 插槽中的

    元素颜色为红色。

    兼容性: 除了IE浏览器,大部分现代浏览器支持。

    :has-slotted

    描述: 匹配 Shadow DOM 中包含指定插槽内容的宿主元素。

    示例:

    :has-slotted(p) {

    border: 1px solid blue;

    }

    内容

    效果: 如果 的 Shadow DOM 中有

    插槽内容,则添加蓝色边框。

    兼容性: Chrome 134+,2025年新特性,截止本文发布(2025/06),仅有Chrome浏览器、Edge浏览器以及火狐浏览器最新版本支持。

    ::target-text

    描述: 匹配当前文本锚点所在的文本。

    示例:

    ::target-text {

    background: yellow;

    }

    文本内容

    效果: 文本锚点内容背景色为黄色。

    兼容性: 大部分现代浏览器仅在2021年后版本支持,Chrome 89+以上版本支持。

    ::column

    描述: 选择多列布局中的列元素。

    示例:

    div::column {

    border: 1px solid black;

    }

    多列内容

    效果: 多列布局中的列添加黑色边框。

    兼容性: Chrome 134+,2025年新特性,截止本文发布(2025/06),仅有Chrome浏览器以及Edge浏览器最新版本支持。

    ::picker()

    描述: 选择表单控件的 picker 界面(如日期选择器)。

    示例:

    input::picker() {

    background: lightblue;

    }

    效果: 日期选择器的 picker 界面背景色为浅蓝色。

    兼容性: Chrome 134+,2025年新特性,截止本文发布(2025/06),仅有Chrome浏览器以及Edge浏览器最新版本支持。

    ::checkmark

    描述: 选择复选框或单选框的勾选标记。

    示例:

    input[type="checkbox"]::checkmark {

    color: green;

    }

    效果: 复选框的勾选标记颜色为绿色。

    兼容性: Chrome 133+,2025年新特性,截止本文发布(2025/06),仅有Chrome浏览器以及Edge浏览器最新版本支持。

    7. 选择器优先级

    选择器的优先级决定了当多个样式规则冲突时,哪个规则生效。以下是优先级计算规则:

    选择器类型权重值示例行内样式1000style="..."ID 选择器100#header类/属性/伪类10.btn, [type="text"], :hover元素/伪元素1p, ::before通用选择器0*

    注意: !important 优先级最高,但应避免使用,因其破坏样式可维护性。示例: #main .highlight p 的优先级为 100 + 10 + 1 = 111。

    参考资料

    MDN Web Docs - CSS SelectorsCSS-Tricks - CSS SelectorsW3Schools - CSS Selectors ReferenceGeeksforGeeks - CSS SelectorsCan I Use - Browser Compatibility