鼠标点击后相对于事件源(event.target)的位置
2018-07-10 本文已影响0人
Lo阿飞ve
function getOffsetXY(evt) {
if (evt.offsetX && evt.offsetY) return {x: evt.offsetX, y: evt.offsetY};
var ele = evt.target || evt.srcElement;
var o = ele;
var x = 0;
var y = 0;
while (o.offsetParent) {
x += o.offsetLeft;
y += o.offsetTop;
o = o.offsetParent;
}
// 处理当元素处于滚动之后的情况
var left = 0;
var top = 0
while (ele.parentNode) {
left += ele.scrollLeft;
top += ele.scrollTop;
ele = ele.parentNode;
}
return {x: evt.pageX + left - x, y: evt.pageY + top - y};
}
用法:
var _x = getOffsetXY(event).x,
_y = getOffsetXY(event).y;