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;
鼠标点击后相对于事件源(event.target)的位置
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 直接上图。 Input里的mouse Properties 代表了点击事件属性 下面的可选项 use mouse ...
- call 方法的使用 官方文档是这么说的:调用一个对象的一个方法,以另一个对象替换当前对象。call 方法可以用来...