热血洒红尘

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

 

   因为最近技术长进缓慢,也没高手带,只能靠自己了,所以想仿个WEBQQ来锻炼下自己。做之前最好先把必要的东西准备好。jquery其实本身的事件机制就很完善了,包括了单击,双击,鼠标移入,鼠标移出等。但是却少了一个做事件。就是鼠标右击事件。当然大家也是直接用侦听鼠标按下事件,然后通过if来判断执行相应的函数。造成鼠标右击事件的效果。

但是这不是我想要的,我想要的似乎这个事件可以跟其它事件比如单击事件一样。可以被方便的使用,而不需要每次都去判断。这里通过编写jquery插件的形式扩展,让这个方法可以直接使用$().rightClick();来使用。

jQuery的插件主要分3种类型

1.封装对象方法的插件

(这种插件是将对象封装起来,用于对通过选择器获取的对象进行操作,也就是这里需要用到的方法)

2.封装全局函数的插件

(可以将独立的函数加入到jquery的命名空间下)

3.选择器插件

(虽然jquery的选择器已经很强大了,但还是会需要扩展一些自己喜欢的选择器)

其它的一些关于插件的知识大家可以自己去查阅相关资料。这里就直接开始讲了。

这里是使用的第一种插件类型,先分析下具体的编写思路。

1.使用鼠标右键事件后,将禁止所有的系统右键菜单功能

2.绑定鼠标右键事件后,实际是触发鼠标按下事件。

3.通过if来判断,如果按下的是右键则执行参数,这个参数只能是函数。如果不是右键则不执行。

相信讲到这里,对jquery很熟悉的也明白要怎么做了。

jquery事件机制扩展,jquery鼠标右键事件。

jquery事件机制扩展,jquery鼠标右键事件。

 

 1 /*鼠标右键插件*/
2 (function($) {
3 $.fn.extend({
4 //定义鼠标右键方法,接收一个函数参数
5 "rightClick":function(fn){
6 //调用这个方法后将禁止系统的右键菜单
7 $(document).bind('contextmenu',function(e){
8 return false;
9 });
10 //为这个对象绑定鼠标按下事件
11 $(this).mousedown(function(e){
12 //如果按下的是右键,则执行函数
13 if(3 == e.which){
14 fn();
15 }
16 });
17 }
18 });
19
20 })(jQuery);

 

jquery事件机制扩展,jquery鼠标右键事件。

使用方法跟其它事件一样

原创非首发,首发自21cpu

原文地址

jquery事件机制扩展,jquery鼠标右键事件。

posted on 2011-12-21 14:14  热血洒红尘  阅读(1161)  评论(2编辑  收藏  举报