各浏览器中鼠标按键值的差异

我们知道标准鼠标有左,中,右三个键。鼠标按下时如何判断按下的是哪个键呢?

W3C DOM-Level-2 定义如下

W3C DOM 写道

During mouse events caused by the depression or release of a mouse button, button is used to indicate which mouse button changed state. The values for button range from zero to indicate the left button of the mouse, one to indicate the middle button if present, and two to indicate the right button. For mice configured for left handed use in which the button actions are reversed the values are instead read from right to left.

 

其描述的很明确,0,1,2分别代表左,中,右三个键。以下分别在mousedown,mouseup,click,dbclick中测试。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<p id="p1">Test mousedown</p>
<p id="p2">Test mouseup</p>
<p id="p3">Test click</p>
<p id="p4">Test dbclick</p>
 
<script type="text/javascript">
    function $(id){return document.getElementById(id)}
     
    var p1 = $('p1'), p2 = $('p2'), p3 = $('p3'), p4 = $('p4');
    p1.onmousedown = function(e){
        e = window.event || e;
        alert(e.button);
    }
    p2.onmouseup = function(e){
        e = window.event || e;
        alert(e.button);
    }
    p3.onclick = function(e){
        e = window.event || e;
        alert(e.button);
    }
    p4.ondbclick = function(e){
        e = window.event || e;
        alert(e.button);
    }      
</script>

  

鼠标左键测试结果
  IE6/7/8 IE9 Firefox4 Chrome12 Safari5 Opera10
mousedown 1 1 0 0 0 0
mouseup 1 1 0 0 0 0
click 0 0 0 0 0 0
dbclick 无响应 无响应 无响应 无响应 无响应 弹出菜单

 

IE6/7/8/9中,mousedown/mouseup 事件中获取左键的值为1,click事件中获取的却是0。
其它浏览器,mousedown/mouseup/click 事件中获取左键值均为0。完全遵循标准。
所有浏览器,dbclick事件中均无法获取

 

鼠标中键测试结果
  IE6/7 IE8/9 Firefox4 Chrome12 Safari5 Opera11
mousedown 4 4 1 1 1 出现方向图标
mouseup 4 4 1 1 1 出现方向图标
click 无响应 0 无响应 1 1 出现方向图标
dbclick 无响应 无响应 无响应 无响应 无响应

出现方向图标

 

IE6/7/8/9中,mousedown/mouseup 事件中获取中键的值为4。
IE6/7中,click事件无法获取中键的值。IE8/9则可以,但值为0。
Firefox4/Chrome12/Safari5中,mousedown/mouseup 事件中获取中键值为1。
Chrome12/Safar5中,click事件也能获取中键值,亦为1。
Opera11中无法获取中键值。

 

鼠标右键测试结果
  IE6/7/8/9 Firefox4 Chrome12 Safari5 Opera11
mousedown 2 2 2 右键菜单,2 先2,再弹右键菜单
mouseup 先2,再弹右键菜单 先2,再弹右键菜单 先2,再弹右键菜单 右键菜单,2 先2,再弹右键菜单
click 弹右键菜单 弹右键菜单 弹右键菜单 弹右键菜单 弹右键菜单
dbclick 弹右键菜单 弹右键菜单 弹右键菜单 弹右键菜单 弹右键菜单

 

所有浏览器,mousedown/mouseup事件中均能获取右键值,且都为2。但某些浏览器会有默认右键菜单行为。
所有浏览器,click/dbclick事件中均不能获取到右键值。

 

从以上测试可看到,判断鼠标按下了哪个键 ,应该选择合适的事件 。这里应选mousedown/mouseup。Opera10中仍然无法获取到中键的值,因为Opera压根不触发中键的事件(mousedown,mouseup,click,dbclick)。

以下代码将IE6/7/8的值转换成符合W3C标准的

1
2
3
4
5
6
7
8
9
10
11
12
13
var ie678 = !-[1,];
function getButton(e){
    var code = e.button;
    var ie678Map = {
        1 : 0,
        4 : 1,
        2 : 2
    }
    if(ie678){
        return ie678Map[code];
    }
    return code;
}

  

posted on   snandy  阅读(3383)  评论(5编辑  收藏  举报

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
< 2011年4月 >
27 28 29 30 31 1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
1 2 3 4 5 6 7

统计

点击右上角即可分享
微信分享提示