例如:
<p id="p1">
<p>
<p>
</p>
</p>
<p>
<p>
</p>
</p>
</p>
在这种情况下我只想取到#p1下的子元素的p,不包括这些子p的更子级的p,该如何做到.
大家讲道理2017-04-10 15:02:37
javascript
var children = document.getElementById('p1').childNodes, output = [] for (var i = 0, ii = children.length; i < ii; i++) { output.push(children[i].nodeName) } console.log(output)
大家讲道理2017-04-10 15:02:37
4楼的方法兼容,但是需要加上nodeType的判断,不然文本结点(TextNode)也会被查出来,如:
var $d = document.getElementById('p1'),
$childs = $d.childNodes,
results = [];
for(var i = 0,len = $childs.length; i < len; i++){
if($childs[i].nodeType === 1){
results.push($childs[i]);
}
}
console.log(results);
当然也可以使用nextSibling进行查找 :)