因為最近技術長進緩慢,也沒高手帶,只能靠自己了,所以想仿個WEBQQ來鍛煉下自己。做之前最好先把必要的東西準備好。jquery其實本身的事件機制就很完善了,包括了單擊,雙擊,滑鼠移入,滑鼠移出等。但是卻少了一個做事件。就是滑鼠右擊事件。當然大家也是直接用偵聽滑鼠按下事件,然後通過if來判斷執行相應的函數。造成滑鼠右擊事件的效果。
但是這不是我想要的,我想要的似乎這個事件可以跟其它事件比如單擊事件一樣。可以被方便的使用,而不需要每次都去判斷。這裡通過編寫jquery外掛程式的形式擴充,讓這個方法可以直接使用$().rightClick();來使用。
jQuery的外掛程式主要分3種類型
1.封裝對象方法的外掛程式
(這種外掛程式是將對象封裝起來,用於對通過選取器擷取的對象進行操作,也就是這裡需要用到的方法)
2.封裝全域函數的外掛程式
(可以將獨立的函數加入到jquery的命名空間下)
3.選取器外掛程式
(雖然jquery的選取器已經很強大了,但還是會需要擴充一些自己喜歡的選取器)
其它的一些關於外掛程式的知識大家可以自己去查閱相關資料。這裡就直接開始講了。
這裡是使用的第一種外掛程式類型,先分析下具體的編寫思路。
1.使用滑鼠右鍵事件後,將禁止所有的系統右鍵菜單功能
2.綁定滑鼠右鍵事件後,實際是觸發滑鼠按下事件。
3.通過if來判斷,如果按下的是右鍵則執行參數,這個參數只能是函數。如果不是右鍵則不執行。
相信講到這裡,對jquery很熟悉的也明白要怎麼做了。
jquery事件機制擴充,jquery滑鼠右鍵事件。
複製代碼 代碼如下:
/*滑鼠右鍵外掛程式*/
(function($) {
$.fn.extend({
//定義滑鼠右鍵方法,接收一個函數參數
"rightClick":function(fn){
//調用這個方法後將禁止系統的右鍵菜單
$(document).bind('contextmenu',function(e){
return false;
});
//為這個對象綁定滑鼠按下事件
$(this).mousedown(function(e){
//如果按下的是右鍵,則執行函數
if(3 == e.which){
fn();
}
});
}
});
})(jQuery);
複製代碼 代碼如下:
$(document).ready(function(e){
$("body").rightClick(function()(alert("按右鍵")));
});
jquery事件機制擴充,jquery滑鼠右鍵事件。
使用方法跟其它事件一樣