jquery實現的右鍵滑鼠點選事件

antzone發表於2017-04-03

jquery其實本身的事件機制就很完善了,包括了單擊,雙擊,滑鼠移入,滑鼠移出等。

但是卻少了一個做事件。就是滑鼠右擊事件。

當然大家也是直接用偵聽滑鼠按下事件,然後通過if來判斷執行相應的函式。造成滑鼠右擊事件的效果。 

但是這往往不是我們想要的,我們想要的似乎這個事件可以跟其它事件比如單擊事件一樣。

可以被方便的使用,而不需要每次都去判斷。

這裡通過編寫jquery外掛的形式擴充套件,讓這個方法可以直接使用$().rightClick();來使用。 

jQuery的外掛主要分3種型別:

(1).封裝物件方法的外掛:

這種外掛是將物件封裝起來,用於對通過選擇器獲取的物件進行操作,也就是這裡需要用到的方法。

(2).封裝全域性函式的外掛:

可以將獨立的函式加入到jquery的名稱空間下。 

(3).選擇器外掛:

雖然jquery的選擇器已經很強大了,但還是會需要擴充套件一些自己喜歡的選擇器。

這裡是使用的第一種外掛型別,先分析下具體的編寫思路。 

(1).使用滑鼠右鍵事件後,將禁止所有的系統右鍵選單功能 

(2).繫結滑鼠右鍵事件後,實際是觸發滑鼠按下事件。 

(3).通過if來判斷,如果按下的是右鍵則執行引數,這個引數只能是函式。如果不是右鍵則不執行。 

相信講到這裡,對jquery很熟悉的也明白要怎麼做了。 

a:3:{s:3:\"pic\";s:43:\"portal/201704/03/233552jc4ltaz110dttyty.jpg\";s:5:\"thumb\";s:0:\"\";s:6:\"remote\";N;}

jquery事件機制擴充套件,jquery滑鼠右鍵事件:

[JavaScript] 純文字檢視 複製程式碼
/*滑鼠右鍵外掛*/
(function($) { 
  $.fn.extend({ 
  //定義滑鼠右鍵方法,接收一個函式引數 
    "rightClick":function(fn){ 
      //呼叫這個方法後將禁止系統的右鍵選單 
      $(document).bind('contextmenu',function(e){ 
        return false; 
      }); 
      //為這個物件繫結滑鼠按下事件 
      $(this).mousedown(function(e){ 
        //如果按下的是右鍵,則執行函式 
        if(3 == e.which){ 
          fn(); 
        } 
      }); 
    } 
  }); 
})(jQuery);

相關文章