«
图解 60 个 CSS 选择器

时间:2024-8   


CSS 选择器用于选择 HTML 元素并将样式应用于它们。使用这些选择器,可以定义特定条件下应用哪些样式。除了普通的选择器外,还有伪类和伪元素,用于选择具有特定状态或特定部分的元素,并将样式应用于它们。本文将通过图文并茂的方式展示这些选择器的使用方法!

选择器 通用选择器

通用选择器使用 *来选择全部元素。

null

元素选择器

同于选择指定 HTML 元素。

null

类选择器

选择具有指定类名的所有元素。

null

ID选择器

选择具有指定ID的元素。

null

组合选择器

连接两个或多个类名或 ID,以选择具有所有指定类名/ID的元素。

null

多重选择器

使用逗号将多个选择器声明分开,这样可以很容易地将相同的样式应用于多个选择器声明。

null

后代选择器

后代选择器表示选择某个元素的所有后代元素,即位于该元素内部的所有子孙元素。在使用后代选择器时,在两个选择器之间加上一个空格,表示前一个选择器所选中的元素中包含的后代元素。

null

相邻选择器

相邻选择器用于选择紧接在另一个元素后面的直接相邻兄弟元素的选择器,使用加号(+)作为组合符号,将两个选择器连接起来。它选择的是位于第一个选择器后紧邻的同级元素。

null

子选择器

子选择器用于选择某个元素的直接子元素,使用大于号(>)作为组合符号,将两个选择器连接起来。它选择的是父级元素下的直接子元素,即元素树结构中的一级关系。

null

通用兄弟选择器

通用兄弟选择器使用波浪号(即通用兄弟组合符)来选择在第一个选择器之前的所有元素,而不要求它们是第一个选择器的直接兄弟元素。

null

猫头鹰选择器

猫头鹰选择器用于选择所有具有前置兄弟元素的元素,用来在一个容器内的元素之间添加间距,但不包括第一个元素,因为第一个元素没有前置兄弟元素。

null

属性选择器

属性选择器用于选择具有特定属性的元素。

null

null

null

null

null

null

伪类 链接伪类选择器

这 4 个伪类用于选择链接处于不同状态的元素。它们最常与链接一起使用,但是 :active也适用于按钮,而 :hover可以用于各种元素:

这 4 个伪类可用于提高用户交互性,例如增加链接的可见度,使其更加显著突出,从而改善用户体验。

null

:focus 伪类

:focus伪类用于选择当前获得焦点的元素。当用户与网页上的表单元素进行交互时,可以通过点击或键盘导航,使某个特定的输入框处于焦点状态。这意味着用户的输入将直接应用到该输入框上。

null

:checked 伪类

:checked伪类用于选择当前被选中或选择的单选按钮、复选框或 select 元素的选项。

null

:disabled 伪类

:disabled伪类用于匹配被禁用的表单元素,例如按钮或文本输入框。

null

:enabled 伪类

:enabled伪类用于匹配可以交互和接收输入的表单元素。

null

:valid 伪类

:valid伪类用于选择具有与其属性(如 pattern、type等)所指定要求相匹配的内容的输入元素。

当 input元素的内容符合其属性所指定的要求时,可以使用 :valid伪类选择它们。

:invalid 伪类

:invalid伪类用于选择具有内容不符合要求的输入元素。

当input元素的内容不符合其要求时,可以使用 :invalid伪类来选择它们。

null

:required 伪类

:required伪类用于选择具有 required属性的输入元素,该属性表示在提交表单之前必须填写它们。

当 input元素具有 required属性时,可以使用 :required伪类选择它们。

null

:optional 伪类

:optional伪类用于选择没有 required属性的输入元素,这意味着它们不是必填项。

当input元素没有 required 属性时,可以使用 :optional伪类选择它们。

null

:first-child 伪类

:first-child伪类用于选择父元素中的第一个子元素。

null

:last-child 伪类

:last-child伪类用于选择父元素中的最后一个子元素。

null

:nth-child 伪类

:nth-child伪类根据元素在父元素中的位置进行选择,允许进行各种选择。:nth-child还可以自定义模式选择元素:

公式中的 n就像一个计数器,可以按重复周期选择元素。例如,:nth-child(3n)将选择每三个元素。

null

:nth-last-child 伪类

:nth-last-child伪类与 :nth-child类似,但是从最后一个子元素向后计数。

null

:only-child 伪类

当需要选择在其父级元素中唯一的一个子元素时,可以使用 :only-child伪类。

null

:first-of-type 伪类

:first-of-type伪类选择在其父元素中的特定类型的元素中的第一个元素。

null

:last-of-type 伪类

:last-of-type伪类选择在其父元素中的特定类型的元素中的最后一个元素。

null

:nth-of-type 伪类

当需要根据元素在兄弟元素中的类型和位置选择元素时,可以使用 :nth-of-type伪类。

null

:nth-last-of-type 伪类

:当需要根据元素在兄弟元素中的类型和位置选择元素,并且从末尾开始计数时,可以使用 :nth-last-of-type伪类。

null

:only-of-type 伪类

当需要选择在其兄弟元素中为特定类型的元素仅有一个的元素时,可以使用 :only-of-type伪类。

null

:target 伪类

:target用于选择具有与 URL 片段匹配的 ID 属性的元素。URL 片段是指 URL 中的 # 符号后面的部分。当从页面中的链接点击跳转到带有特定片段的 URL 时,:target伪类将会被应用于与片段匹配的对应元素上。这样可以利用 :target来为被直接链接到的页面部分设置不同的样式,从而提供视觉上的反馈和突出显示。

null

:not 伪类

使用 :not伪类可以选择不符合指定选择器或条件的元素。这在需要排除某些特定元素时非常有用。

null

has 伪类

使用 :has伪类可以选择包含某个特定元素或选择器的父级元素,并为其应用样式。

null

其他伪类

除了上面提到的伪类,CSS中还包含以下伪类:

伪元素 ::before 伪元素

::before伪元素用于在元素内容之前插入内容。它可以用于添加装饰性内容、图标或其他不需要出现在实际 DOM 中的元素。

::after 伪元素

::after伪元素与 ::before伪元素类似,用于在元素的内容之后插入内容。

null

::first-letter 伪元素

::first-letter伪元素用于选择并修改块级元素的第一个字母,从而应用特定的样式。这个伪元素只能选择每个块级元素的第一个字母,并且仅在有文本内容的时候生效。

null

::first-line 伪元素

::first-line伪元素用于选择并修改块级元素的第一行,从而应用特定的样式。这个伪元素只能选择每个块级元素的第一行,并且仅在有文本内容的时候生效。

null

::placeholder 伪元素

::placeholder伪元素用于选择并修改表单字段的占位符文本,从而应用特定的样式。占位符文本是在用户未输入任何内容时显示的默认文本。

null

::selection 伪元素

::selection伪元素用于选择并修改用户所选文本的样式。可以应用于包含文本内容的任何元素,如段落、标题、按钮等。

null

::marker 伪元素

::marker伪元素用于为列表项中的标记符设置样式,这些标记符通常包含无序列表的项目符号或有序列表的数字/字母。

null

其他伪元素

除了上述伪元素之外,CSS 还提供了以下伪元素:

---END---