CSS伪类是一种允许选择文档中特定状态或位置的CSS选择器。它们用于选择不同状态下的元素,而无需改变HTML标记的内容。伪类以冒号(:
)开头,紧随其后的是伪类的名称。它们与选择器结合使用,以定义在特定条件下应用的样式。伪类的主要作用是允许开发者根据用户的交互、文档结构或其他条件来选择元素,从而实现更加动态和交互性的样式。
li:first-child {
color: red;
}
li:last-child {
color: blue;
}
li:nth-child(odd) {
background-color: #f2f2f2;
}
li:nth-last-child(2) {
font-weight: bold;
}
p:nth-of-type(2n) {
color: green;
}
p:nth-last-of-type(odd) {
text-decoration: underline;
}
h2:first-of-type {
font-size: 24px;
}
span:last-of-type {
border: 1px solid #ccc;
}
div:only-child {
background-color: yellow;
}
p:only-of-type {
color: purple;
}
input:not([type="submit"]) {
border: 1px solid #999;
}
a:hover {
color: orange;
}
button:active {
background-color: #ccc;
}
input:focus {
border: 2px solid blue;
}
#section1:target {
background-color: lightyellow;
}
a:link {
color: blue;
}
a:visited {
color: purple;
}
form:focus-within {
border: 2px solid #555;
}
input[type="checkbox"]:checked {
border-color: green;
}
input:disabled {
background-color: #eee;
}
input:enabled {
background-color: #fff;
}
p:empty {
display: none;
}
用法::is(selector)
或 :matches(selector)
示例:选择所有段落和标题元素,其中至少一个具有类名为 “important” 的元素。
:is()
伪类允许您组合多个选择器,只要其中至少一个选择器匹配元素,整个选择器就匹配。这有助于简化复杂的选择器,提高代码的可读性。
:is(p, h1, h2, h3):is(.important)
用法::where(selector)
或 :matches(selector)
示例:选择所有段落和标题元素,其中至少一个具有类名为 “important” 的元素。
:where()
与 :is()
类似,允许组合多个选择器。与 :is()
不同的是,:where()
不会影响特异性,因此它更适合用于提高代码的可读性而不引入额外的特异性。
:where(p, h1, h2, h3):where(.important)
用法::has(selector)
示例:选择所有包含至少一个带有类名为 “highlight” 的子元素的 div
元素。
:has()
伪类用于选择包含特定后代的元素。如果指定的选择器匹配元素的后代,那么包含这些后代的元素就会被选择。这在需要选择包含特定内容的父元素时非常有用。
div:has(.highlight)
:matches()多条件支持:允许在一个选择器中同时匹配多个条件,类似于逗号分隔的选择器列表,但更灵活。
p:matches(:hover, :active) {}