2011-01-11 91 views
0

我動態創建下拉工作下拉菜單,如:使用JavaScript代碼jQuery的UL李菜單問題

<dl id="sample-1" class="dropdown"> 
    <dt id="1"><a href="#" id="1"><span>Please select the country</span></a></dt> 
    <dd> 
     <ul> 
      <li><anchortag>Brazil fdsf sdf kjdsh hkjh jkh hdf sdh kjh sdfh kjh k hkjh 2121 fgfd21g 21 21g dfg1 f21gfd2<span class="value">BR</span></ahchor></li> 
      <li><anchortag>France<span class="value">FR</span></ahchor></li> 
      <li><anchortag>Germany<span class="value">DE</span></ahchor></li> 
      <li><anchortag>India<span class="value">IN</span></ahchor></li> 
      <li><anchortag>Japan<span class="value">JP</span></ahchor></li> 
      <li><anchortag>Serbia<span class="value">CS</span></ahchor></li> 
      <li><anchortag>United Kingdom<span class="value">UK</span></ahchor></li> 
      <li><anchortag>United States<span class="value">US</span></ahchor></li> 
     </ul> 
    </dd> 
</dl> 
<span id="result-1"></span> 

<script> $('dl[id^="sample-"] dt a').click(function(e) { 
    e.preventDefault(); 
    //$('dl[id^="sample-"] dd ul').toggle();      $(this).closest('dt').siblings('dd').find('ul').toggle(); 
}); 

$('dl[id^="sample-"]').each(function() { 
    var mainOjbect = this; 
    //$(this.closest('dt').find('a')).live('click', function(e) {           
    $("dl[id^='sample-'] dd ul li a").live('click', function(e) { 
     var text = $(this).html(); 
     alert(text); 
     alert(mainOjbect.id + "id is...."); 
     $('#' + mainOjbect.id + " dt a span").html(text); 
     //$(this).closest('dt').find('a').find('span').html(text); 
     //$("dl[id^='sample-'] dd ul").hide();    
     $('#' + mainObject + "ul").hide(); 
     $(this).find('dl[id^="result-"]').html("Selected value is: " + getSelectedValue(this)); 
    }); 
}); 

function getSelectedValue(id) { 
    alert(id); 
    return $("#" + id).find("dt a span.value").html(); 
} 

$(document).bind('click', function(e) { 
    alert('hello3'); 
    var $clicked = $(e.target); 
    if (!$clicked.parents().hasClass("dropdown")) 
    //$("dl[id^='sample-'] dd ul").hide(); 
    $(this).closest('dt').siblings('dd').find('ul').hide(); 
}); < /script> 

這些所有的菜單都被動態地創建使用JavaScript克隆功能和接下來將是

<dl id="sample-2" class="dropdown"> 
... 
... 
... 
<dl id="sample-n" class="dropdown"> 

但我不明白當我點擊一個菜單sele ction正在另一個菜單上完成,我想在他們的位置運行所有這些菜單。我花了足夠的時間,但沒有弄清楚我的代碼有誤。 需要幫助如何遍歷所有這些。

感謝

+1

請你重新格式化您的代碼? – roman 2011-01-11 16:21:40

回答

1

正如我已經interpretted烏爾問題遍歷用戶點擊後的所有菜單項u能這樣做下面...

$('.dropdown').live('click',function(){ 


    $('li').each(function(){ 

    var $idOfli=$(this).attr('id'); 
    . 
    . 
    . 
    } 

    });