源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-09-18 11:44 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:读jQuery之七 判断点击了鼠标哪个键的代码
jQuery丢弃了标准的 [url=http://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-MouseEvent-button]button[/url] 属性采用 [url=https://developer.mozilla.org/en/DOM/event.which]which[/url],这有点让人费解。 which 是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。 jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。 即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用which。它一举两用了。 源码
[url=http://api.jquery.com/event.which/]event.which[/url] 中并没有提到which可以表示鼠标按键值,只提到了表示键盘按键值。 源码中的注释也让人误解。
[u]复制代码[/u] 代码如下:
// Add which for click: 1 === left; 2 === middle; 3 === right
注意这里说的是click ,很容易让人使用click 事件,但实际上click事件中获取是错误的。 下面就用 click 事件试试:
[u]复制代码[/u] 代码如下:
<!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也无能为力。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部