它接受一个哈希参数,都是可选项。哈希的el为要绑定鼠标事件的元素,left为点击左键激发的事件,其他两个类推。用法如下: 复制代码 代码如下: var el = document.getElementById("mouse"); var ex = document.getElementById("explanation"); var left = function(){ ex.innerHTML = "左键被按下"; } var right = function(){ ex.innerHTML = "右键被按下"; } mouseEvent({el:el,left:left,middle:null,right:right});
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行] 此外,通过鼠标在网页上的点击,我们还可以获得许多有用的参数,如获得当前鼠标的坐标。根据其参照物的不同,分为以下几套坐标系。一套是以当前浏览器的可视区为参照物(clientX, clientY),另一套是以显示器的屏幕为参照物(screenX, screenY)。此外微软还有一套坐标系(x,y),它是相对于触发事件的对象的offsetParent的,火狐有另一套坐标系(pageX, pageY),它是相对于当前网页的。我们可以通过如下函数来获得鼠标在网页的坐标。 复制代码 代码如下: var getCoordInDocument = function(e) { e = e || window.event; var x = e.pageX || (e.clientX + (document.documentElement.scrollLeft || document.body.scrollLeft)); var y= e.pageY || (e.clientY + (document.documentElement.scrollTop || document.body.scrollTop)); return {'x':x,'y':y}; }
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行] (clientX,clientY)的坐标系,不受滚动条影响 至于mouseover,mousemove,mouseout没有什么好说,并且无浏览器差异。我们来看鼠标滚轮事件,这个差异很严重。IE、Safari、 Opera 、chrome是mousewheel事件,Firefox是DOMMouseScroll事件。事件属性方面,IE等是event. wheelDelta,Firefox是event. detail。IE等往上滚一圈为120,往下滚一圈为-120。Firefox往上滚一圈为-3,往下滚一圈为3。我们可以构造一个函数来削除它们的差异。 复制代码 代码如下: var mouseScroll = function(fn){ var roll = function(){ var delta = 0, e = arguments[0] || window.event; delta = (e.wheelDelta) ? e.wheelDelta / 120 : -(e.detail || 0) / 3; fn(delta);//回调函数中的回调函数 } if(/a/[-1]=='a'){ document.addEventListener('DOMMouseScroll', roll, false); }else{ document.onmousewheel = roll; } }
此函数接受一函数作为参数,如: 复制代码 代码如下: mouseScroll(function(delta){ var obj = document.getElementById('scroll'), current = parseInt(obj.offsetTop)+(delta*10); obj.style.top = current+"px"; });