作家
登录

读jQuery之七 判断点击了鼠标哪个键的代码

作者: 来源:www.28hudong.com 2013-03-30 00:51:14 阅读 我要评论

jQuery丢弃了标准的 button 属性采用 which,这有点让人费解。which 是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用which。它一举两用了。源码 复制代码 代码如下: // Add which for key events if ( event.which == null && (event.charCode != null || event.keyCode != null) ) { event.which = event.charCode != null ? event.charCode : event.keyCode; } // Add which for click: 1 === left; 2 === middle; 3 === right // Note: button is not normalized, so don't use it if ( !event.which && event.button !== undefined ) { event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) )); } 标准的button采用0,1,2表示鼠标的左,中,右键。jQuery的which则使用用1,2,3。还有一点让人不爽的是jQuery文档 event.which 中并没有提到which可以表示鼠标按键值,只提到了表示键盘按键值。源码中的注释也让人误解。复制代码 代码如下: // Add which for click: 1 === left; 2 === middle; 3 === right 注意这里说的是click ,很容易让人使用click 事件,但实际上click事件中获取是错误的。 下面就用 click 事件试试: 复制代码 代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <title></title> <script src="http://code.jquery.com/jquery-1.6.1.js"></script> <script type="text/javascript"> $(document).click(function(e){ alert(e.which); }) </script> </head> <body> </body> </html> 测试结果 IE6/7/8 IE9 Firefox4 Chrome12 Safari Opera 点击左键 0 1 1 1 1(不停弹出alert) 1 点击中键 不响应 2 2 2 2(不停弹出alert) 不响应 点击右键 仅弹出右键菜单 仅弹出右键菜单 3,弹出右键菜单 仅弹出右键菜单 仅弹出右键菜单 仅弹出右键菜单 可以看到使用 click 事件并不能按照jQuery设想的那样左,中,右键对应的1,2,3值。各浏览器下均不一致,且右键根本获取不到,Safari中还不停的弹出alert。因此,应该使用 mousedown / mouseup 事件则达到jQuery的设想。jQuery的注释误导了人。此外即使使用 mousedown / mouseup 事件,Opera中也无法获取中键的值。Opera的恶心做法令jQuery也无能为力。

  推荐阅读

  jQuery UI AutoComplete 使用说明

介绍 在 jQuery UI 的最近更新中增加了自动完成控件 AutoComplete,这为我们提供了又一个强大的开发工具,这里介绍一下这个控件的使用方式。 首先,jQuery UI 是基于 jQuery 的,所以,必须在你的页面中首先引用 j>>>详细阅读


本文标题:读jQuery之七 判断点击了鼠标哪个键的代码

地址:http://www.17bianji.com/kaifa2/JS/24507.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)