读jq之七(判断点击了鼠标哪个键)

jQuery丢弃了标准的 button 属性采用which,这有点让人费解。

which 是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。

jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。
即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用which。它一举两用了。

见jQuery1.4.4源码

 

 

标准的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 事件试试:

 

 

使用 click 事件,响应函数中直接alert出e.which。我们分别点击左,中,右键测试。

 

测试结果
IE6/7/8IE9betaFirefoxChromeSafariOpera
点击左键01111(不停弹出alert)1
点击中键不响应12不响应2(不停弹出alert)不响应
点击右键仅弹出右键菜单仅弹出右键菜单仅弹出右键菜单仅弹出右键菜单仅弹出右键菜单仅弹出右键菜单

 

 

可以看到使用 click 事件并不能按照jQuery设想的那样左,中,右键对应的1,2,3值。各浏览器下均不一致,且右键根本获取不到,Safari中还不停的弹出alert。

 

因此,应该使用 mousedown / mouseup 事件则达到jQuery的设想。jQuery的注释误导了人。

 

此外即使使用 mousedown / mouseup 事件,Opera中也无法获取中键的值。Opera的恶心做法令jQuery也无能为力。

 

这一点见 各浏览器中鼠标按键值的差异  。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值