2016-12-06 144 views
1

http://codepen.io/oliecs/pen/womLPJ綁定初始點擊事件(A)後點擊事件(B)導致事件B火災立即

var nav = { 

    init: function() { 
     console.log('nav init'); 

     $nav = $('nav'); 
     $navIcon = $('.nav-icon'); 

     $navIcon.on('click',function(){ 
      nav.show(); 
     }) 
    }, 

    show: function() { 
     console.log('nav show'); 

     $nav.addClass('active'); 
     $_DOCUMENT.on('click.navisopen',function(){ //document is a global variable 
      nav.close(); 
     }) 
    }, 

    close: function() { 
     console.log('nav close'); 

     $nav.removeClass('active'); 
     $_DOCUMENT.off('.navisopen'); 
    } 
}; 

我覺得筆比我描述這更好。我想單擊導航圖標打開導航,然後在此之後的任何點擊都會關閉導航。但是,在第一次點擊後立即觸發關閉事件,導致導航功能即時打開和關閉。我不知道如何做到這一點。

+0

更新JS是最初的單擊事件仍在處理中,當您添加另一個事件處理它,然後第一個事件處理程序完成後得到執行? –

回答

1

您需要

$navIcon.on('click',function(event){ 
     event.stopPropagation(); 
     nav.show(); 
    }) 

因爲首次點擊是冒泡的DOM一路到該觸發事件處理程序的文檔。

+0

非常完美,非常感謝。 – nicedevman

2

file..Use這個代碼

var ecs= {}; 
    ecs.common = (function($) { 
    var $_DOCUMENT = $(document), 
    $_WINDOW = $(window), 
    $nav = $('nav'), 
    $navIcon = $('.nav-icon'); 
    var nav = { 
     init: function() { 
      console.log('nav init'); 
      $nav = $('nav'); 
      $navIcon = $('.nav-icon'); 
      $navIcon.on('click',function(){ 
       nav.show(); 
      }) 
     }, 
     show: function() { 
      console.log('nav show'); 
      $nav.addClass('active'); 
      // $_DOCUMENT.on('click.navisopen',function(){ 
      //  nav.close(); 
      // }) 
     }, 
     close: function() { 
      console.log('nav close'); 
      $nav.removeClass('active'); 
      $_DOCUMENT.off('.navisopen'); 
     } 
    }; 
    //-------------------- 
    // DOM Ready 
    //-------------------- 
    $(function() { 
     nav.init(); 
    }); 

    $(document).mouseup(function (e) { 
     var container = $(".nav-icon"); 
     if (!container.is(e.target) && container.has(e.target).length === 0) { 
      /* if the target of the click isn't the container && nor a descendant of the container */ 
      $nav.removeClass('active'); 
     } 
    }); 
})(jQuery); 
+0

我會重寫它以在'mouseup'中使用'nav.close',因爲它可以保持乾燥。 「click」工作時有沒有理由使用'mouseup'?這兩個不一定是可以互換的 – AndFisher