概述 nth-child selector
返回值:Array<Element(s)>
描述:选择的他们所有父元素的第n个子元素。
index: 每个相匹配子元素的索引值,从1
开始,也可以是字符串 even
或 odd
,或一个方程式( 例如 :nth-child(even)
, :nth-child(4n)
)。
因为jQuery的实现:nth-child(n)
是严格来自CSS规范,所以n
值是“1索引”,也就是说,从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)个一(n是基于0)被选中。
这个不寻常的用法,可进一步讨论中找到 W3C CSS specification.
看下面一个示例:
- <div class="test">
- <p>A元素</p>
- <p>B元素</p>
- <div>C元素</div>
- <p>D元素</p>
- </div>
看下面的代码
- $("p:nth-child(2)")//B元素被选中
p:nth-child(2)
选择器选择B元素,p:nth-child(2)
选择器要满足的条件是:
<div class="test">
的第二个子元素是p元素,所以满足条件,B元素就被中了。
jQuery 1.9新增了:nth-of-type()
选择器,和这个:nth-child()
比较容易混淆,具体查看:nth-of-type()
中的比较说明。
示例
在每个 ul 查找第 2 个li
<ul>
<li>John</li>
<li>Karl</li>
<li>Brandon</li>
</ul>
<ul>
<li>Glen</li>
<li>Tane</li>
<li>Ralph</li>
</ul>
$("ul li:nth-child(2)")
[ <li>Karl</li>, <li>Tane</li> ]
查找每个匹配的 ul 中的第二个 li,并将它标记出来。
- <!doctype html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <title>nth-child demo</title>
- <style>
- div {
- float: left;
- }
- span {
- color: blue;
- }
- </style>
- <script src="https://code.jquery.com/jquery-1.10.2.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 lang="en">
- <head>
- <meta charset="utf-8">
- <title>nth-child demo</title>
- <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="https://code.jquery.com/jquery-1.10.2.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>