浏览 3993 次
锁定老帖子 主题:读jq之七(判断点击了鼠标哪个键)
精华帖 (0) :: 良好帖 (3) :: 新手帖 (0) :: 隐藏帖 (0)
|
|||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
作者 | 正文 | ||||||||||||||||||||||||||||
发表时间:2010-12-03
最后修改:2010-12-09
jQuery丢弃了标准的 button
属性采用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。 jq1.4.4源码 写道
// Add which for click: 1 === left; 2 === middle; 3 === right
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <script src="jquery-1.4.4.js"></script> <script type="text/javascript"> $(document).click(function(e){ alert(e.which); }) </script> </head> <body> </body> </html> 使用 click 事件,响应函数中直接alert出e.which。我们分别点击左,中,右键测试。
可以看到使用 click 事件并不能按照jQuery设想的那样左,中,右键对应的1,2,3值。各浏览器下均不一致,且右键根本获取不到,Safari中还不停的弹出alert。
因此,应该使用 mousedown / mouseup 事件则达到jQuery的设想。jQuery的注释误导了人。
此外即使使用 mousedown / mouseup 事件,Opera中也无法获取中键的值。Opera的恶心做法令jQuery也无能为力。
这一点见 各浏览器中鼠标按键值的差异 。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||
发表时间:2010-12-09
瀏覽器的差異真讓人無奈。。。
|
|||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||