javascript中的递归函数

javascript中的递归函数,javascript,recursion,Javascript,Recursion,也许这是一个很小的问题,我不知道为什么这个函数在else语句上运行时会退出for循环。 我需要这个函数来获取xml文档 function xmlToArray(element){ childs= element.childNodes; if(childs.length != 1){ for(var i=0;i<childs.length;i++){ if(childs[i].hasChildNodes()){ xmlToArr

也许这是一个很小的问题,我不知道为什么这个函数在else语句上运行时会退出for循环。 我需要这个函数来获取xml文档

function xmlToArray(element){
    childs= element.childNodes;
    if(childs.length != 1){
      for(var i=0;i<childs.length;i++){
        if(childs[i].hasChildNodes()){
          xmlToArray(childs[i]);
        }
        alert("exit from if");
      }//end for
      alert("exit from for");
    }//end if
    else{
      alert("do something with element");
    }
    alert("end of func");
}
函数xmlToArray(元素){
childs=element.childNodes;
如果(儿童长度!=1){

对于(var i=0;i由于
childs
不是一个局部变量,因此
xmlToArray
的所有调用都处理相同的数据

试试这个:

function xmlToArray(element) {
    var childs = element.childNodes;
    // …
}

使用
var
在当前范围内声明该变量。

您的意思是,当它遇到else时,它会从堆栈中完全删除,每次迭代都是如此,还是仅仅是它所在的级别?