浪人_J
2015-03-11 23:36
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>nextSibling</title> </head> <body> <ul id="u1"> <li id="a">javascript</li> <li id="b">jquery</li> <li id="c">html</li> </ul> <ul id="u2"> <li id="d">css3</li> <li id="e">php</li> <li id="f">java</li> </ul> <script type="text/javascript"> function get_nextSibling(n){ var x=n.nextSibling; while (x && x.nodeType!=1){ x=x.nextSibling; } return x; } var x=document.getElementsByTagName("li")[0]; document.write(x.nodeName); document.write(" = "); document.write(x.innerHTML); var y=get_nextSibling(x); if(y!=null){ document.write("<br />nextsibling: "); document.write(y.nodeName); document.write(" = "); document.write(y.innerHTML); }else{ document.write("<br>已经是最后一个节点"); } function get_previousSibling(n){ var a=n.previousSibling; while(a&&a.nodeType!=1){ a=a.previousSibing; } } var a=document.getElementsByTagName("li")[2]; document.write("<br/>"+a.nodeName); document.write("="); document.write(a.innerHTML); var b=get_previousSibling(a); if(b!=null){ document.write("<br/>previoussibling:"); document.write(b.nodeName); document.write("="); document.write(b.innerHTML); } else{ document.write("<br/>已经是第一个节点"); } </script> </body> </html>
第49行,为什么下标要写成2?我疑惑的是2是怎么来的?
因为getElementByTagName("li")是获取所有的li元素,得到的结果是一个数组,加上[2]是表示只获取第三个li
获取名字为li元素数组中的第三个元素,也就是邮标为2的元素
JavaScript进阶篇
468197 学习 · 21891 问题
相似问题