语法
伪元素的语法:
selector:pseudo-element {property:value;}
CSS 类也可以与伪元素配合使用:
selector.class:pseudo-element {property:value;}
:first-line 伪元素
"first-line" 伪元素用于向文本的首行设置特殊样式。
在下面的例子中,浏览器会根据 "first-line" 伪元素中的样式对 p 元素的第一行文本进行格式化:
实例
p:first-line$ N: t8 }, I1 H; p# P' Y2 S
{
8 Z- z( g; k) c color:#ff0000;
4 t+ r) T: R) U! [. t* \) h6 T font-variant:small-caps;" \+ M+ E" ^) x$ c( R4 `- \
}
0 c& _7 P6 ?9 T$ O0 G
亲自试一试
注释:"first-line" 伪元素只能用于块级元素。
注释:下面的属性可应用于 "first-line" 伪元素:
- font
- color
- background
- word-spacing
- letter-spacing
- text-decoration
- vertical-align
- text-transform
- line-height
- clear
:first-letter 伪元素
"first-letter" 伪元素用于向文本的首字母设置特殊样式:
p:first-letter0 o1 M4 |9 K4 }1 }, |3 N7 N
{
/ B9 d2 Y+ s! R3 K! K3 R color:#ff0000;" J+ [: \3 } k. k" c$ o
font-size:xx-large;+ j1 b- b* _0 u3 K- l' }' W ]
}
6 s# y; w, e( e( z+ n
亲自试一试
注释:"first-letter" 伪元素只能用于块级元素。
注释:下面的属性可应用于 "first-letter" 伪元素:
- font
- color
- background
- margin
- padding
- border
- text-decoration
- vertical-align (仅当 float 为 none 时)
- text-transform
- line-height
- float
- clear
伪元素和 CSS 类
伪元素可以与 CSS 类配合使用:
p.article:first-letter
% T, ~$ }) B0 L; c
{- w( L0 l( W( Q) p2 x6 x8 J
color: #FF0000;4 I2 }, ]( y. R4 [! u% D
}
/ o% D, s n# S% U( R% S; ]! i- B0 Z" H" v, _
<p class="article">This is a paragraph in an article。</p># Q* Y# `9 w V2 @3 h! ] @
上面的例子会使所有 class 为 article 的段落的首字母变为红色。
多重伪元素
可以结合多个伪元素来使用。
在下面的例子中,段落的第一个字母将显示为红色,其字体大小为 xx-large。第一行中的其余文本将为蓝色,并以小型大写字母显示。段落中的其余文本将以默认字体大小和颜色来显示:
p:first-letter
+ u& b5 |; f2 j8 ?: q6 y {
- [; ?6 o9 v7 J( ]8 @ color:#ff0000;! ~# W8 |. Y' Y6 ^
font-size:xx-large;
1 K+ O- p7 S& f( C }
/ d) }! M8 b7 P
' b/ O& R3 I7 Tp:first-line- `/ S7 g+ _; ^
{3 x4 S4 ~( W8 d- u; g3 S
color:#0000ff;
, C5 B8 h, |" L1 Z$ z% d font-variant:small-caps;
5 M( f$ o: r7 A$ l& H }& ?: {1 R* `( j
亲自试一试
CSS2 - :before 伪元素
":before" 伪元素可以在元素的内容前面插入新内容。
下面的例子在每个 <h1> 元素前面插入一幅图片:
h1:before; A$ m! Q* \7 m
{
2 r# A0 \5 v% j: h content:url(logo.gif);
9 a: O8 M7 B, L/ ^( @' W$ z$ d }
! I4 j; Q8 w8 K3 I8 r# N
亲自试一试
CSS2 - :after 伪元素
":after" 伪元素可以在元素的内容之后插入新内容。
下面的例子在每个 <h1> 元素后面插入一幅图片:
h1:after
0 c* P& Y' `. o7 M! r, } {
) z8 p8 }) ^* r# F content:url(logo.gif);
, A' i# K7 A$ p; B5 n: F, V, U$ s }
6 K! n$ b. |* ?4 C# k; ?
亲自试一试
伪元素
W3C:"W3C" 列指示出该属性在哪个 CSS 版本中定义(CSS1 还是 CSS2)。