选择相邻兄弟
如果需要选择紧接在另一个元素后的元素,而且二者有相同的父元素,可以使用相邻兄弟选择器(Adjacent sibling selector)。
例如,如果要增加紧接在 h1 元素后出现的段落的上边距,可以这样写:
h1 + p {margin-top:50px;}这个选择器读作:“选择紧接在 h1 元素后出现的段落,h1 和 p 元素拥有共同的父元素”。
亲自试一试
语法解释
相邻兄弟选择器使用了加号(+),即相邻兄弟结合符(Adjacent sibling combinator)。
注释:与子结合符一样,相邻兄弟结合符旁边可以有空白符。
请看下面这个文档树片段:
<div>: t( g& k# J; J% r9 Z( J5 Z0 p
<ul>6 Q1 I% j2 f/ t# q2 Z! O4 f
<li>List item 1</li>
2 c- u7 f& P, h. F/ u2 R1 e <li>List item 2</li>
9 U9 {+ |1 o' t <li>List item 3</li>1 K4 \6 q! n# B/ y# e
</ul>9 Y; J c( d$ B9 J Y
<ol>
8 V2 z# {9 S4 ?8 H <li>List item 1</li>
9 I9 L& _- Y- y- f+ Q2 m$ o" N <li>List item 2</li>
- w2 O8 }5 ?6 {' m& L, @ <li>List item 3</li>
! }7 r# G- M* [: g$ _ </ol>
* z9 y3 e' c( F; n& b/ L% C* V</div>% D b0 P9 p- w# j
在上面的片段中,div 元素中包含两个列表:一个无序列表,一个有序列表,每个列表都包含三个列表项。这两个列表是相邻兄弟,列表项本身也是相邻兄弟。不过,第一个列表中的列表项与第二个列表中的列表项不是相邻兄弟,因为这两组列表项不属于同一父元素(最多只能算堂兄弟)。
请记住,用一个结合符只能选择两个相邻兄弟中的第二个元素。请看下面的选择器:
li + li {font-weight:bold;}上面这个选择器只会把列表中的第二个和第三个列表项变为粗体。第一个列表项不受影响。
亲自试一试
结合其他选择器
相邻兄弟结合符还可以结合其他结合符:
html > body table + ul {margin-top:20px;}这个选择器解释为:选择紧接在 table 元素后出现的所有兄弟 ul 元素,该 table 元素包含在一个 body 元素中,body 元素本身是 html 元素的子元素。