2

クリックされたリスト要素ごとに簡単なメニューを作成したいのですが、外側をクリックするとこのdivは非表示になります。うまくいけば意味のあるいくつかの簡単なコードがあります。

$('.drillFolder').click(function(){
    var id = $(this).attr('data-folder');
    $(".drillDownFolder ul li > a").attr('data-id', id);
    $(".drillDownFolder").show();
});

$("body").click(function(e){
    if(e.target.className !== "drillDownFolder")
    {
      $(".drillDownFolder").hide();
    }       
});

//The hidden div
<div class="drillDownFolder" style="display:none">
    <ul>
        <li><a href="#" data-id="">Show Image</a></li>
        <li><a href="#" data-id="">Edit Image</a></li>
    </ul>
</div>

メニューが.drillFolderリンクを介して表示され、ボディクリックがすぐに非表示になるので、何が問題なのかわかります。どうすればこれを回避できますか。

アドバイスいただければありがとうございます

4

2 に答える 2

9

stopPropagation()を使用して、クリックイベントが.drillFolderコールバックから伝播するのを停止できます。

$('.drillFolder').click(function(event){
    event.stopPropagation();
    var id = $(this).attr('data-folder');
    $(".drillDownFolder ul li > a").attr('data-id', id);
    $(".drillDownFolder").show();
});

$("body").click(function(e){
    $(".drillDownFolder").hide();
});
于 2010-05-02T15:28:28.547 に答える
0
isClicked = function($i, e){
  return $i.length>0 && $(e.target).parents().andSelf().index($i)>-1  ;
}

$ iは$('#myDiv')のようなjQueryオブジェクトであり、eはイベントオブジェクトです

$(document).click(function(e) { 
    if( !isClicked( $('#myDiv') , e ) ) alert('not myDiv '); 
});
于 2012-12-20T14:08:58.620 に答える