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

时间:2024-05-05 09:15:28 

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中测试。


<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>


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

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

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

即:
IE6/7/8中,mousedown/mouseup 事件中获取中键的值为4。
IE6/7中,click事件无法获取中键的值。IE8则可以,但值为0。
Firefox3.6/Chrome7/Safari5中,mousedown/mouseup 事件中获取中键值为1。
Chrome7/Safar5中,click事件也能获取中键值,亦为1。
Opera10中无法获取中键值。

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

即:
所有浏览器,mousedown/mouseup事件中均能获取右键值,且都为2。
所有浏览器,click/dbclick事件中均不能获取到右键值。

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

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


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;
}

标签:鼠标按键值
0
投稿

猜你喜欢

  • 学习 YUI3 中的沙箱机制

    2010-04-12 12:52:00
  • asp日期时间格式化函数

    2009-12-14 12:56:00
  • 对Python3中列表乘以某一个数的示例详解

    2023-05-05 03:10:40
  • 推荐:怎么用javascript进行拖拽

    2007-09-21 20:14:00
  • python日期与时间戳的各种转换示例

    2021-05-23 07:47:33
  • Python监听剪切板实现方法代码实例

    2023-11-10 13:48:32
  • node.js应用后台守护进程管理器Forever安装和使用实例

    2024-05-03 15:36:48
  • ASP3.0中的流控制能力

    2008-10-19 17:41:00
  • Facebook:产品设计评价体系解密

    2011-05-24 17:13:00
  • 利用Python删除电脑中重复文件的方法

    2023-06-19 21:58:20
  • ASP把数字用逗号每3位隔开显示代码

    2008-01-02 13:11:00
  • Python3实现捕获Ctrl+C终止信号

    2021-10-17 14:03:55
  • Python实现PS滤镜中马赛克效果示例

    2021-05-25 20:56:59
  • 解决Python 使用h5py加载文件,看不到keys()的问题

    2021-10-04 06:19:15
  • Element-ui DatePicker显示周数的方法示例

    2024-05-29 22:45:19
  • Python爬虫之pandas基本安装与使用方法示例

    2023-11-26 21:49:35
  • python处理列表的部分元素的实例详解

    2021-04-16 01:13:05
  • 原生JS实现非常好看的计数器

    2024-04-19 09:59:20
  • Django 简单实现分页与搜索功能的示例代码

    2023-12-26 01:40:16
  • Python使用sklearn库实现的各种分类算法简单应用小结

    2022-08-05 22:37:59
  • asp之家 网络编程 m.aspxhome.com