本节分享的这段代码,用于获取节点的兄弟,父级与子级元素。
代码如下:
 
复制代码 代码示例:
<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>