您好,欢迎访问一九零五行业门户网

用javascript获取当页面上鼠标光标位置和触发事件的对象的代码_javascript技巧

用javascript获取鼠标位置:
复制代码 代码如下:
function mouseposition(ev) {
if (ev.pagex || ev.pagey) {
return {
x: ev.pagex,
y: ev.pagey
};
}
return {
x: ev.clientx + document.body.scrollleft - document.body.clientleft,
y: ev.clienty + document.body.scrolltop - document.body.clienttop
};
}
document.onmousemove = mousemove;
function mousemove(ev){
ev = ev || window.event;
var mousepos = mouseposition(ev);
}
关于代码的详细说明,原文中已经介绍,现转到此处:
我们首先要声明一个 evnet 对象,无论移动、点击、按键等,都会激活一个 evnet ,在 internet explorer 里, event 是全局变量,会被存储在 window.event 里. 在 firefox 或者其他浏览器,event 会被相应的函数获取.当我们将mousemove函数赋值于document.onmousemove,mousemove 会获取鼠标移动事件。
为了让 ev 在所有浏览器下获取了 event 事件,在firefox下||window.event将不起作用,因为ev已经有了赋值。在 msie 中 ev 为空,所以得到 window.event 。
因为在这篇文章中我们需要多次获取鼠标位置,所以我们设计了一个 mouseposition 函数,它包含一个参数 : event 。
因为我们要在 msie 和其他浏览器下运行,firefox 和其他浏览器用 event.pagex 和 event.pagey 来表示鼠标相对于文档的位置,如果你有一个 500*500 的窗口并且你的鼠标在绝对中间,那么 pagex 和 pagey 的值都是 250,如果你向下滚动 500, 那么 pagey 将变成 750。
msie 正好相反,它使用 event.clientx 和 event.clienty 表示鼠标相当于窗口的位置,而不是文档。在同样的例子中,如果你向下滚动500,clienty 依然是 250,因此,我们需要添加 scrollleft 和 scrolltop 这两个相对于文档的属性。最后,msie 中文档并不是从 0,0 开始,而是通常有一个小的边框(通常是 2 象素),边框的大小定义在 document.body.clientleft 和 clienttop 中,我们也把这些加进去。
很幸运,我们现在已经用 mouseposition 函数解决了坐标问题,不需为此费心了。
用javascript获取触发事件的对象
复制代码 代码如下:
关键还是event对象在多浏览器下的兼容性,和上面方式是一样的,这里代码就不做说明了
其它类似信息

推荐信息