< p id = "p1" >Test mousedown</ p > |
02 |
< p id = "p2" >Test mouseup</ p > |
03 |
< p id = "p3" >Test click</ p > |
04 |
< p id = "p4" >Test dbclick</ p > |
06 |
< script type = "text/javascript" > |
07 |
function $(id){return document.getElementById(id)} |
09 |
var p1 = $('p1'), p2 = $('p2'), p3 = $('p3'), p4 = $('p4'); |
10 |
p1.onmousedown = function(e){ |
11 |
e = window.event || e; |
14 |
p2.onmouseup = function(e){ |
15 |
e = window.event || e; |
18 |
p3.onclick = function(e){ |
19 |
e = window.event || e; |
22 |
p4.ondbclick = function(e){ |
23 |
e = window.event || e; |
即:
IE6/7/8中,mousedown/mouseup 事件中获取左键的值为1,click事件中获取的却是0。
其它浏览器,mousedown/mouseup/click 事件中获取左键值均为0。完全遵循标准。
所有浏览器,dbclick事件中均无法获取
即:
IE6/7/8中,mousedown/mouseup 事件中获取中键的值为4。
IE6/7中,click事件无法获取中键的值。IE8则可以,但值为0。
Firefox3.6/Chrome7/Safari5中,mousedown/mouseup 事件中获取中键值为1。
Chrome7/Safar5中,click事件也能获取中键值,亦为1。
Opera10中无法获取中键值。
即:
所有浏览器,mousedown/mouseup事件中均能获取右键值,且都为2。
所有浏览器,click/dbclick事件中均不能获取到右键值。
以上可看到,判断鼠标按下了哪个键 ,应该选择合适的事件 。这里应选mousedown/mouseup。Opera10中仍然无法获取到中键的值,因为Opera压根不触发中键的事件(mousedown,mouseup,click,dbclick)。
以下代码将IE6/7/8的值转换成符合W3C标准的
02 |
function getButton(e){ |
10 |
return ie678Map[code]; |