前几天在工作中遇见一个问题。就是要判断鼠标点击后 相对于事件源(event.target)的位置。
当然可以用event.offsetX,event.offsetY,来获取到。 但是到了FF里面就挂了。 event.layerX 也不获取不到。
干脆就自己写了个方法,
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.paren