:nth-child(index/even/odd/equation)
如果某个元素是其父元素中的第 n 个子元素,那么它就会被选中。
-
1.1.4 新增:nth-child(index/even/odd/equation)
index (Number/String) 用于匹配子元素的索引值,可以是从1
开始计数的数字、字符串even
和odd
, 或者是一个表达式(或公式)。(比如:nth-child(even)
,:nth-child(4n)
)
由于 jQuery 中的 :nth-child(n)
是严格按照 CSS 规范设计的,所以这里 n
的数值是从 1 开始计数的。然而,所有其它的选择器表达式中,jQuery 遵从的是 JavaScript 以 0 开始计数的规范。因此,如果一个 <ul>
含有两个 <li>
,那么 $('li:nth-child(1)')
选中的是第一个 <li>
,而 $('li:eq(1)')
选中的是第二个。
:nth-child(n)
伪类很容易跟 :eq(n)
混淆起来,然而两者匹配元素有着很大的差异。 用 :nth-child(n)
时,不论子元素是何种元素,它们都会被计数(即,成为候选元素),只有与这个伪类前面的选择器相匹配的元素才会被选中。如果用 :eq(n)
时,只有与这个伪类前面的选择相匹配的元素才会被计数(即,成为候选元素),而不管它们是否是哪个元素的子元素,并且最终选中的是第 n+1 个元素(因为是从 0 开始计数的)。
关于这个不寻常用法的深入探讨,可以在 W3C CSS 规范 中找到。
示例:
查找每个匹配的 ul 中的第二个 li,并将它标记出来。
<!DOCTYPE html>
<html>
<head>
<style>
div { float:left; }
span { color:blue; }
</style>
<script src="jquery.min.js"></script>
</head>
<body>
<div><ul>
<li>John</li>
<li>Karl</li>
<li>Brandon</li>
</ul></div>
<div><ul>
<li>Sam</li>
</ul></div>
<div><ul>
<li>Glen</li>
<li>Tane</li>
<li>Ralph</li>
<li>David</li>
</ul></div>
<script>
$("ul li:nth-child(2)").append("<span> - 2nd!</span>");
</script>
</body>
</html>
演示:
示例:
这个例子展示了刚才提到的两个容易混淆的选择器是如何工作的。注意这里的 :even 和 :odd 会无视它们的父元素,而仅仅把元素列表中的元素每隔一个过滤出来。而 :nth-child 则会计算子元素在各自父元素中的索引值。很多时候,直接看例子会比空讲要容易理解的多...
<!DOCTYPE html>
<html>
<head>
<style>
button { display:block; font-size:12px; width:100px; }
div { float:left; margin:10px; font-size:10px;
border:1px solid black; }
span { color:blue; font-size:18px; }
#inner { color:red; }
td { width:50px; text-align:center; }
</style>
<script src="jquery.min.js"></script>
</head>
<body>
<div>
<button>:nth-child(even)</button>
<button>:nth-child(odd)</button>
<button>:nth-child(3n)</button>
<button>:nth-child(2)</button>
</div>
<div>
<button>:nth-child(3n+1)</button>
<button>:nth-child(3n+2)</button>
<button>:even</button>
<button>:odd</button>
</div>
<div><table>
<tr><td>John</td></tr>
<tr><td>Karl</td></tr>
<tr><td>Brandon</td></tr>
<tr><td>Benjamin</td></tr>
</table></div>
<div><table>
<tr><td>Sam</td></tr>
</table></div>
<div><table>
<tr><td>Glen</td></tr>
<tr><td>Tane</td></tr>
<tr><td>Ralph</td></tr>
<tr><td>David</td></tr>
<tr><td>Mike</td></tr>
<tr><td>Dan</td></tr>
</table></div>
<span>
tr<span id="inner"></span>
</span>
<script>
$("button").click(function () {
var str = $(this).text();
$("tr").css("background", "white");
$("tr" + str).css("background", "#ff0000");
$("#inner").text(str);
});
</script>
</body>
</html>