jquery实现的右键鼠标点击事件

快乐打工仔 分类:实例代码

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);

回复

我来回复
  • 暂无回复内容