例如有xhtml如下:
ol id="sample1" li列表项哦列表项/li li列表项哦列表项/li li列表项哦列表项/li li列表项哦列表项/li/ol
CSS如下:
#sample1 li:nth-child(even) { /* #sample1的子元素中排序为奇数的li */background:#FF9; /* 也可以设定float、margin、border等属性 */}#sample1 li:nth-child(odd) {background:#FC3;}
其显示如图4-41所示。
图4-41 E:nth-child(n)的应用1
也可以实现三色甚至多色的背景。例如下列代码:
#sample2 li:nth-child(3n+1) {background:#F90;}#sample2 li:nth-child(3n+2) {background:#Fc3;}#sample2 li:nth-child(3n) {background:#FF9;}ol id="sample2" li列表项哦列表项/li li列表项哦列表项/li /ol
其显示如图4-42所示。
图4-42 E:nth-child(n)的应用2
此时需注意的是,3n+1表示的是3行循环内的第1行,而3n则是第3行。
同时,也可以指定某一个特定的子元素,例如下列代码:
#sample3 li:nth-child(1) {color:#F00;}#sample3 li:nth-child(2) {color:#F60;}#sample3 li:nth-child(3) {color:#FC0;}h4前3名不同显示的排行榜/h4ol id="sample3" li列表项哦列表项/li li列表项哦列表项/li li列表项哦列表项/li /ol
分别指定了第1、2、3个li的前景颜色color,其显示如图4-43所示。
图4-43 E:nth-child(n)的应用3
也可以为同一列的单元格td指定相同的背景色:
#sample4 td:nth-child(3n+1) {background:#FCC;}#sample4 td:nth-child(3n+2) {background:#F99;}#sample4 td:nth-child(3n+3) {background:#C6F;}table border="0" cellspacing="0" cellpadding="0" id="sample4" trtd1-1/tdtd1-2/tdtd1-3/td /tr /table
其显示如图4-44所示。
图4-44 E:nth-child(n)的应用4
但是,需要特别注意的是,父元素内所有的子元素都参与排序,而无论元素的类型是什么,在上面的例子中,子元素的类型都是单一的(li或者td),而下面这个例子中,子元素的类型不再单一(包括dt和dd):
dl id="sample5" dtdt 1,总排行1/dt dddd 1,总排行2/dd dtdt 2,总排行3/dt dddd 2,总排行4/dd dddd 3,总排行5/dd dtdt 3,总排行6/dt dtdt 4,总排行7/dt dddd 4,总排行8/dd/dl
如果设定如下的CSS,那么其显示的效果则如图4-45所示。
#sample5 dt {font-weight:bolder;}#sample5 dt:nth-child(odd){background:#6CF;}
图4-45 E:nth-child(n)包括父元素内所有类型的子元素
由图4-45读者可以发现,判断dt是否为奇数的条件是其在子元素内总排序,而不是dt元素单独排序。
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)实例演示如下:
[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]