本节分享的这段代码,用于获取节点的兄弟,父级与子级元素。
代码如下:
复制代码 代码示例:
<div id="test">
<div></div>
<div></div>
</div>
<script>
/**
* 获取节点元素
* 兄弟节点、父级节点、子级元素节点
* by www.jb200.com
*/
function dom() {
var s= document.getElementById("test");
del_ff(s); //清理空格
var chils= s.childNodes; //得到s的全部子节点
var par=s.parentNode; //得到s的父节点
var ns=s.nextSbiling; //获得s的下一个兄弟节点
var ps=s.previousSbiling; //得到s的上一个兄弟节点
var fc=s.firstChild; //获得s的第一个子节点
var lc=s.lastChile; //获得s的最后一个子节点
}
</script>
代码说明:
var b =document.getElementById("test").childNodes;
此时b.length 在IE浏览器中没问题,其依旧等于2,但是在FF浏览器中则会使4,是因为FF把换行也当做一个元素了。
所以,在此,需遍历这些元素,把元素类型为空格而且是文本都删除。
如下:
复制代码 代码示例:
<script>
/**
* 遍历节点元素 去除空格
* edit by www.jb200.com
*/
function del_ff(elem){
var elem_child = elem.childNodes;
for(var i=0; i<elem_child.length;i++){
if(elem_child[i].nodeName == "#text" && !/s/.test(elem_child.nodeValue))
{
elem.removeChild(elem_child)
}
}
}
</script>