1.childNodes,获取子节点,本身就是一个数组,可以通过下标childNodes[i]来获取某个子节点。

alert(obj.childNodes.length);    //高级浏览器会有空白节点的存在

//循环根据节点的nodeType类型来判断是不是元素节点
for(var i = 0, len = aElement.childNodes.length; i < len; i++){
  if(aElement.childNodes[i].nodeType == 1){
    aElement.childNode[i].style.background = "red";
  }
}

2.首尾子节点

firstChild,firstElementChild;

lastChild,lastElementChild;

3.兄弟节点

previousSibling,previousElementSibling;

nextSibling,nextElementSibling;

//用if来判断firstChild与firstElementChild来兼容

if(obj.firstElementChild){
  obj.firstElementChild.style.background = "red";
}else{
  obj.firstChild.style.background = "red";
}

其他节点同理

//删除空白节点,来兼容firstChild

function cleanWhiteSpace(element){
  for(var i = 0; i < element.chiledNodes.length; i++){
    var node = element.childNodes[i];      //循环当前的子节点
    if(node.nodeType == 3 && !/\S/.test(node.nodeValue)){  
      node.parentNode.removeChild();    //\S匹配任何可见字符,当节点是文本节点与是!/\S/,非可见字符的时候,就删除这些节点
    }
  }
}

4.父元素parentNode

//点击当前a标签,查找a标签的父级,然后隐藏

var arrA = document.getElementsByTagName("a");
  for(var i = 0, len = arrA.length; i < len; i++){
    arrA[i].onclick = function(){
      this.parentNode.style.display = "none"
    }
  }

5.用className选择元素

//选取class为box的li,将其变色

var aLi = document.getElementsByTagName("li");
for(var i = 0, len = aLi.length; i < len; i++){
  if(aLi[i].className == "box"){
    this.style.background = "red";
  }
}
//封装

function getByClass(objParent,targetClass){
  var aResult = [];
  var aElement =objParent.getElementsByTagName("*");
  for(var i = 0, len = aElement.length; i < len; i++){
    if(aElement[i].className == targetClass){
      aResult.push(aElement[i]);
    }
  }
  return aResult;            //返回class为box的数组
} //调用 var aBox = getByClass(aNav,"box");      //得到class为box的数组 for(var i = 0, len = aBox.length; i < len; i++){
  aBox[i].style.background = "red";
}
05-11 17:34