读jq之七(判断点击了鼠标哪个键)
2010-12-15 14:41
211 查看
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。我们分别点击左,中,右键测试。
测试结果
可以看到使用 click
事件并不能按照jQuery设想的那样左,中,右键对应的1,2,3值。各浏览器下均不一致,且右键根本获取不到,Safari中还不停的弹出alert。
因此,应该使用 mousedown / mouseup 事件则达到jQuery的设想。jQuery的注释误导了人。
此外即使使用 mousedown / mouseup 事件,Opera中也无法获取中键的值。Opera的恶心做法令jQuery也无能为力。
这一点见 各浏览器中鼠标按键值的差异
。
属性采用which,这有点让人费解。
which
是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。
jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。
即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用which。它一举两用了。
见jQuery1.4.4源码
// 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 http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <mce:script src="jquery-1.4.4.js" mce_src="jquery-1.4.4.js"></mce:script> <mce:script type="text/javascript"><!-- $(document).click(function(e){ alert(e.which); }) // --></mce:script> </head> <body> </body> </html>
使用 click
事件,响应函数中直接alert出e.which。我们分别点击左,中,右键测试。
IE6/7/8 | IE9beta | Firefox | Chrome | Safari | Opera | |
点击左键 | 0 | 1 | 1 | 1 | 1(不停弹出alert) | 1 |
点击中键 | 不响应 | 1 | 2 | 不响应 | 2(不停弹出alert) | 不响应 |
点击右键 | 仅弹出右键菜单 | 仅弹出右键菜单 | 仅弹出右键菜单 | 仅弹出右键菜单 | 仅弹出右键菜单 | 仅弹出右键菜单 |
事件并不能按照jQuery设想的那样左,中,右键对应的1,2,3值。各浏览器下均不一致,且右键根本获取不到,Safari中还不停的弹出alert。
因此,应该使用 mousedown / mouseup 事件则达到jQuery的设想。jQuery的注释误导了人。
此外即使使用 mousedown / mouseup 事件,Opera中也无法获取中键的值。Opera的恶心做法令jQuery也无能为力。
这一点见 各浏览器中鼠标按键值的差异
。
相关文章推荐
- js判断鼠标左、中、右键哪个被点击的方法
- 读jQuery之七 判断点击了鼠标哪个键的代码
- 读jQuery之七 判断点击了鼠标哪个键的代码
- 读jQuery之七(判断点击了鼠标哪个键)
- 判断鼠标点击事件点下的是哪个键
- 根据鼠标左键点击判断是哪个控件
- 如何在45度地图中判断鼠标点击的是哪个菱形
- 读jQuery之七(判断点击了鼠标哪个键)
- 读jQuery之七(判断点击了鼠标哪个键)
- jQ点击那个栏目,给哪个栏目加样式,根据url判断
- 读jQuery之七(判断点击了鼠标哪个键)
- 读jQuery之七(判断点击了鼠标哪个键)
- js判断鼠标左、中、右键哪个被点击的方法
- jQuery事件函数-点击、双击、键盘按键、鼠标滑动、失去焦点、显示哪个 DOM 元素触发了事件/返回事件的类型。等
- Javascript判断鼠标在元素外点击
- 判断是鼠标拖拽还是点击
- unity3D基础学习 通过判断鼠标点击的是否是目标物体,物体旋转,滑动滚轮缩放拉近视角
- jquery判断鼠标点击的位置是否在规定的div范围内部
- UGUI判断鼠标或手指(移动平台)是否点击在UGUI上
- 用jq实现点击右边内容实现,左边内容切换、自动切换,当鼠标放上右边li上面,左边内容停止切换。