问答详情
源自:9-14 删除节点removeChild()

为什么是for(var i=x.childNodes.length-1;i>=0;i--)

function clearText() {

  var x=document.getElementById("content");

  for(var i=x.childNodes.length-1;i>=0;i--){

      var childNode=x.childNodes[i];

      x.removeChild(childNode);

  }  

}


提问者:listenlo 2016-04-27 15:41

个回答

  • kuban
    2016-04-27 16:36:35
    已采纳

     for(var i=x.childNodes.length-1;i>=0;i--)这句是要倒着删除,这个应该能理解吧

    这个练习题正着删除倒着删除都能做,倒着删除相比不用考虑太多,正常写就好,因为总是从最后一个删除,正着删除的话需要从第一个删除,也就是

    for(var i=0;i<x.childNodes.length;i++){

          var childNode=x.childNodes[0];//总从第一个删除

          x.removeChild(childNode);

      }

    如果按

    for(var i=0;i<x.childNodes.length;i++){

          var childNode=x.childNodes[i];

          x.removeChild(childNode);

      }  

    这种写法,会漏删,导致一次删不干净。

    比如childNode读出来{h1,h2,h3,h4,h5}

    然后i=0,删了h1,没问题,继续

    i=1,此时childNode变成了{h2,h3,h4,h5},删除childNode[1],就是删除了h3

    这里就看出来了吧,会漏删,i=3的时候就没东西可删了,然后这次循环就结束了,但是还有h2,h4被漏下来了。