2011-10-16 175 views
0

当我上面的代码在到达的OPTGROUP结束,它停止...不读的最后一个选项元素......这是怎么回事?感谢递归错误

的console.log( '进入');

  • 这是HTML 选择--- 选项 OPTGROUP --- 选项 选项 选项

    var t,v = ''; 
    
    el = $(selector).get(0); 
    
    if(el.hasChildNodes()){ 
    
         var li = '<ul>' ; 
         for(var i = 0; i < el.childNodes.length; i++){ 
           console.log('-----'+i+' '+el.childNodes[i].nodeName); 
           //console.log(el.childNodes[i].nodeName + ' -> '+ $(el.childNodes[i]).text()); 
           if(el.childNodes[i].nodeName == 'OPTION'){ 
    
            t = $(el.childNodes[i]).text(); 
            v = $(el.childNodes[i]).val(); 
    
            li = li + "<li value='"+v+"' >"+t+"</li>"; 
    
           }else if(el.childNodes[i].nodeName == 'OPTGROUP'){ 
    
            if(el.childNodes[i].hasChildNodes()){ 
             var c = MacOsxSelectOptionToLi(el.childNodes[i]); 
             /*var c = '<ul>'; 
             for(var j = 0; j < el.childNodes[i].childNodes.length; j++){ 
               if(el.childNodes[i].childNodes[j].nodeName == 'OPTION'){ 
                t = $(el.childNodes[i].childNodes[j]).text(); 
                v = $(el.childNodes[i].childNodes[j]).val(); 
                c = c + "<li value='"+v+"' >"+t+"</li>"; 
               }         
             } 
             c = c+ '</ul>'; 
             */ 
            }else{ 
             var c = ''; 
            } 
            var t = $(el.childNodes[i]).attr('label');       
            li = li + "<li class='optiongroup' >"+t+c+"</li>"; 
    
           } 
    
    
    
         } 
    
         return li + '</ul>'; 
    } 
    
+1

如果HTML和脚本放在http://jsfiddle.net/中,这将会有所帮助。 –

回答

0

看,如果你已经宣布整个代码中函数MacOsxSelectOptionToLi()并使用选择器来获取html select元素,代码将进行无限递归。因此,从其他功能进行呼叫。例如。

function initFunction() { 
    var convertSelectToULCode = MacOsxSelectOptionToLi($(selector)); 
}