CSS 伪元素
什么是伪元素?
CSS 伪元素用于为元素的特定部分添加样式。
例如,它可以用于
- 为元素的第一行或第一个字母添加特殊样式
- 在元素内容之前或之后插入内容
语法
伪元素的语法
selector::pseudo-element {
property: value;
}
The ::first-line 伪元素
The ::first-line
伪元素用于为文本的第一行添加特殊样式。
以下示例格式化所有 <p> 元素中的文本第一行
注意: ::first-line
伪元素只能应用于块级元素。
以下属性适用于 ::first-line
伪元素
- 字体属性
- 颜色属性
- 背景属性
- word-spacing
- letter-spacing
- text-decoration
- vertical-align
- text-transform
- line-height
- clear
注意双冒号符号 - ::first-line
与 :first-line
双冒号符号替换了 CSS3 中伪元素的单冒号符号。这是 W3C 为了区分伪类和伪元素而做出的尝试。
在 CSS2 和 CSS1 中,单冒号语法用于伪类和伪元素。
为了向后兼容,单冒号语法对于 CSS2 和 CSS1 伪元素是可接受的。
The ::first-letter 伪元素
The ::first-letter
伪元素用于为文本的第一个字母添加特殊样式。
以下示例格式化所有 <p> 元素中的文本第一个字母:
注意: ::first-letter
伪元素只能应用于块级元素。
以下属性适用于 ::first-letter 伪元素:
- 字体属性
- 颜色属性
- 背景属性
- 外边距属性
- 内边距属性
- 边框属性
- text-decoration
- vertical-align(仅当 "float" 为 "none" 时)
- text-transform
- line-height
- float
- clear
伪元素和 HTML 类
伪元素可以与 HTML 类结合使用:
上面的示例将以红色和更大的尺寸显示带有 class="intro" 的段落中的第一个字母。
多个伪元素
也可以组合多个伪元素。
在以下示例中,段落的第一个字母将以红色显示,并使用 xx-large 字体大小。第一行的其余部分将以蓝色显示,并使用小写字母。段落的其余部分将使用默认的字体大小和颜色
示例
p::first-letter {
color: #ff0000;
font-size: xx-large;
}
p::first-line {
color: #0000ff;
font-variant: small-caps;
}
试一试 »
CSS - The ::before 伪元素
The ::before
伪元素可用于在元素内容之前插入一些内容。
以下示例在每个 <h1> 元素的内容之前插入一个图像
CSS - The ::after 伪元素
The ::after
伪元素可用于在元素内容之后插入一些内容。
以下示例在每个 <h1> 元素的内容之后插入一个图像
CSS - The ::marker 伪元素
The ::marker
伪元素选择列表项的标记。
以下示例为列表项的标记添加样式
CSS - ::selection 伪元素
The ::selection
伪元素匹配用户选中的元素部分。
以下 CSS 属性可以应用于 ::selection
:color
、background
、cursor
和 outline
。
以下示例使选定文本在黄色背景上为红色。
所有 CSS 伪元素
选择器 | 示例 | 示例描述 |
---|---|---|
::after | p::after | 在每个 <p> 元素的内容之后插入内容 |
::before | p::before | 在每个 <p> 元素的内容之前插入内容 |
::first-letter | p::first-letter | 选择每个 <p> 元素的第一个字母 |
::first-line | p::first-line | 选择每个 <p> 元素的第一行 |
::marker | ::marker | 选择列表项的标记 |
::selection | p::selection | 选择用户选中的元素部分 |
所有 CSS 伪类
选择器 | 示例 | 示例描述 |
---|---|---|
:active | a:active | 选择活动链接 |
:checked | input:checked | 选择每个已选中的 <input> 元素 |
:disabled | input:disabled | 选择每个禁用的 <input> 元素 |
:empty | p:empty | 选择每个没有子元素的 <p> 元素 |
:enabled | input:enabled | 选择每个启用的 <input> 元素 |
:first-child | p:first-child | 选择每个作为其父元素第一个子元素的 <p> 元素 |
:first-of-type | p:first-of-type | 选择每个作为其父元素第一个 <p> 元素的 <p> 元素 |
:focus | input:focus | 选择具有焦点的 <input> 元素 |
:hover | a:hover | 选择鼠标悬停时的链接 |
:in-range | input:in-range | 选择值在指定范围内的 <input> 元素 |
:invalid | input:invalid | 选择所有具有无效值的 <input> 元素 |
:lang(language) | p:lang(it) | 选择每个 lang 属性值为以 "it" 开头的 <p> 元素 |
:last-child | p:last-child | 选择每个作为其父元素最后一个子元素的 <p> 元素 |
:last-of-type | p:last-of-type | 选择每个作为其父元素最后一个 <p> 元素的 <p> 元素 |
:link | a:link | 选择所有未访问的链接 |
:not(selector) | :not(p) | 选择每个不是 <p> 元素的元素 |
:nth-child(n) | p:nth-child(2) | 选择每个作为其父元素第二个子元素的 <p> 元素 |
:nth-last-child(n) | p:nth-last-child(2) | 从最后一个子元素开始计数,选择每个作为其父元素第二个子元素的 <p> 元素 |
:nth-last-of-type(n) | p:nth-last-of-type(2) | 从最后一个子元素开始计数,选择每个作为其父元素第二个 <p> 元素的 <p> 元素 |
:nth-of-type(n) | p:nth-of-type(2) | 选择每个作为其父元素第二个 <p> 元素的 <p> 元素 |
:only-of-type | p:only-of-type | 选择每个作为其父元素唯一 <p> 元素的 <p> 元素 |
:only-child | p:only-child | 选择每个作为其父元素唯一子元素的 <p> 元素 |
:optional | input:optional | 选择没有 "required" 属性的 <input> 元素 |
:out-of-range | input:out-of-range | 选择值不在指定范围内的 <input> 元素 |
:read-only | input:read-only | 选择指定了 "readonly" 属性的 <input> 元素 |
:read-write | input:read-write | 选择没有 "readonly" 属性的 <input> 元素 |
:required | input:required | 选择指定了 "required" 属性的 <input> 元素 |
:root | root | 选择文档的根元素 |
:target | #news:target | 选择当前活动的 #news 元素(单击包含该锚点名称的 URL) |
:valid | input:valid | 选择所有具有有效值的 <input> 元素 |
:visited | a:visited | 选择所有已访问的链接 |