语法:
:nth-child(an+b)
为什么选择她,因为我认为,这个选择器是最多学问的一个了。很可惜,据我所测,目前能较好地支持她的只有Opera9+和Safari3+。
描述:
伪类:nth-child()的参数是an+b,如果按照w3.org上的描述,写成中文,很可能会让人头晕,再加上笔者的文笔水平有限,所以我决定避开an+b的说法,把它拆分成5种写法共5部分来说明。
:nth-child(number)
直接匹配第number个元素。参数number必须为大于0的整数。
例子:
li:nth-child(3){background:orange;}/*把第3个LI的背景设为橙色*/
:nth-child(an)
匹配所有倍数为a的元素。其中参数an中的字母n不可缺省,它是倍数写法的标志,如3n、5n。
例子:
li:nth-child(3n){background:orange;}/*把第3、第6、第9、…、所有3的倍数的LI的背景设为橙色*/
:nth-child(an+b) 与 :nth-child(an-b)
先对元素进行分组,每组有a个,b为组内成员的序号,其中字母n和加号+不可缺省,位置不可调换,这是该写法的标志,其中a,b均为正整数或0。如3n+1、5n+1。但加号可以变为负号,此时匹配组内的第a-b个。(其实an前面也可以是负号,但留给下一部分讲。)
例子:
li:nth-child(3n+1){background:orange;}/*匹配第1、第4、第7、…、每3个为一组的第1个LI*/
li:nth-child(3n+5){background:orange;}/*匹配第5、第8、第11、…、从第5个开始每3个为一组的第1个LI*/
li:nth-child(5n-1){background:orange;}/*匹配第5-1=4、第10-1=9、…、第5的倍数减1个LI*/
li:nth-child(3n±0){background:orange;}/*相当于(3n)*/
li:nth-child(±0n+3){background:orange;}/*相当于(3)*/
:nth-child(-an+b)
此处一负一正,均不可缺省,否则无意义。这时与:nth-child(an+1)相似,都是匹配第1个,但不同的是它是倒着算的,从第b个开始往回算,所以它所匹配的最多也不会超过b个。
例子:
li:nth-child(-3n+8){background:orange;}/*匹配第8、第5和第2个LI*/
li:nth-child(-1n+8){background:orange;}/*或(-n+8),匹配前8个(包括第8个)LI,这个较为实用点,用来限定前面N个匹配常会用到*/
:nth-child(odd) 与 :nth-child(even)
分别匹配序号为奇数与偶数的元素。奇数(odd)与(2n+1)结果一样;偶数(even)与(2n+0)及(2n)结果一样。<table class="table"> <tr><td>第一行</td></tr> <tr><td>第二行</td></tr> <tr><td>第三行</td></tr> <tr><td>第四行</td></tr> </table> <style> .table tr:nth-child(odd){ background-color:white; } .table tr:nth-child(even){ background-color:gray; } .table tr:hover{ background-color:yellow; } </style>
<!DOCTYPE html><html><head><title>问答题2</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><style></style></head><body><table id="main" border="1px"><tr><td>1</td><td>1</td><td>1</td></tr><tr><td>2</td><td>2</td><td>2</td></tr><tr><td>3</td><td>3</td><td>3</td></tr><tr><td>4</td><td>4</td><td>4</td></tr><tr><td>5</td><td>5</td><td>5</td></tr><tr><td>6</td><td>6</td><td>6</td></tr><script>$(function(){$("#main tr:even").css("background-color","gray");$("#main tr:odd").css("background-color","white");$("#main tr").mouseenter(function(){$(this).css("background-color","yellow");}).mouseleave(function(){$("#main tr:even").css("background-color","gray");$("#main tr:odd").css("background-color","white");})});</script></table></body></html>
<table class="table"> <thead> <tr> <th>ID</th> <th>Name</th> <th>Sex</th> </tr> </thead> <tbody> <tr> <td>001</td> <td>Tom</td> <td>F</td> </tr> <tr> <td>002</td> <td>Jim</td> <td>M</td> </tr> <tr> <td>003</td> <td>Peter</td> <td>F</td> </tr> </tbody> </table>
.table{ border: 1px solid #ccc; border-collapse: collapse; } .table td,.table th{ border: 1px solid #ccc; } .table tr:nth-child(odd){ background-color: white; } .table tr:nth-child(even){ background-color: gray; } .table tr:hover{ background-color: yellow; }
<!-- 倾斜一个表格以及对应的css,使表格奇数行为白色背景,偶数为灰色,鼠标移上去为黄色 --><!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>tbody tr:nth-child(odd) { background: #fff; }tbody tr:nth-child(even) { background: #eee; }tbody tr:hover { background: #fab646; }</style></head><body><table><thead><th>NUMBER</th></thead><tbody><tr><td>ONE</td></tr><tr><td>TWO</td></tr><tr><td>THREE</td></tr><tr><td>FOUR</td></tr><tr><td>FIVE</td></tr></tbody></table></body></html>
<!doctype html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <style> table tr:nth-of-type(2n){ background-color: #ccc;} table tr:nth-of-type(2n+1){ background-color: #fff;} table tr:hover{ background-color: yellow;} </style> </head> <body> <table> <tr> <td>1</td> <td>2</td> <td>3</td> </tr> <tr> <td>4</td> <td>5</td> <td>6</td> </tr> <tr> <td>7</td> <td>8</td> <td>9</td> </tr> </table> </body> </html>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>test</title> <style> #td{ width:100%; } #td tr{ width:80%; } #td tr:hover{ background-color: yellow !important; } </style> </head> <body> <table id="td"> <tr><td>第一行</td></tr> <tr><td>第二行</td></tr> <tr><td>第三行</td></tr> <tr><td>第四行</td></tr> </table> <script> var tb = document.getElementById("td"); var trs = tb.getElementsByTagName("tr"); for(var i in trs){ if(0 == i%2){ console.log(trs[i]) trs[i].style.backgroundColor = '#eee'; } } </script> </body> </html>