JavaScript 获取鼠标点击坐标五种方式及兼容性

举报
福州司马懿 发表于 2021/11/19 05:12:47 2021/11/19
【摘要】 转自 http://www.poorren.com/javascript-got-mouse-position/ 关于js鼠标事件综合各大浏览器能获取到坐标的属性总共以下五种 event.client...

转自 http://www.poorren.com/javascript-got-mouse-position/

关于js鼠标事件综合各大浏览器能获取到坐标的属性总共以下五种

  • event.clientX/Y
  • event.pageX/Y
  • event.offsetX/Y
  • event.layerX/Y
  • event.screenX/Y

clientX/Y:

clientX/Y获取到的是触发点相对浏览器可视区域左上角距离,不随页面滚动而改变

兼容性:所有浏览器均支持

pageX/Y:

pageX/Y获取到的是触发点相对文档区域左上角距离,会随着页面滚动而改变

兼容性:除IE6/7/8不支持外,其余浏览器均支持

offsetX/Y:

offsetX/Y获取到是触发点相对被触发dom的左上角距离,不过左上角基准点在不同浏览器中有区别,其中在IE中以内容区左上角为基准点不包括边框,如果触发点在边框上会返回负值,而chrome中以边框左上角为基准点。

兼容性:IE所有版本,chrome,Safari均完美支持,Firefox不支持

layerX/Y:

layerX/Y获取到的是触发点相对被触发dom左上角的距离,数值与offsetX/Y相同,这个变量就是firefox用来替代offsetX/Y的,基准点为边框左上角,但是有个条件就是,被触发的dom需要设置为position:relative或者position:absolute,否则会返回相对html文档区域左上角的距离

兼容性:IE6/7/8不支持,opera不支持,IE9/10和Chrome、Safari均支持

screenX/Y:

screenX/Y获取到的是触发点相对显示器屏幕左上角的距离,不随页面滚动而改变

兼容性:所有浏览器均支持

以上内容收集自网络

日常工作中,常用到offsetX,下面提供两个据说比较靠谱的获取方案,兼容多浏览器,欢迎指正。

方案一(在使用,获取的是在当前页面内的全局坐标,若需要使用相对父级容器的坐标,可以使用jQuery的offset或者原生js等方式获取元素坐标,进一步计算,鼠标相对元素的相对坐标):

var getPosition = function(event) {
    var e = event || window.event;
    return {
        x: e.pageX || e.clientX + document.documentElement.scrollLeft || document.body.scrollLeft,
        y: e.pageY || e.clientY + document.documentElement.scrollTop || document.body.scrollTop
    };
};
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

原生js获取元素所在坐标,用于计算鼠标在元素内的相对坐标

var getElPosition = function(el){
    var t = el.offsetTop,
        l = el.offsetLeft;
    while( el = el.offsetParent){
        t += el.offsetTop;
        l += el.offsetLeft;
    }
    return {
        x : l ,
        y : t
    };
};
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

方案二(获取相对父级容器的坐标,但是这个方法在IE11模拟的IE8下好像有点问题,推荐采用第一种方案进行改进):

var getPosition = function(event){
    var evt =event||window.event;
    var srcObj = evt.target || evt.srcElement;
    if (evt.offsetX){
        return {
            x:evt.offsetX,
            y:evt.offsetY
        };
    }else{
        var rect = srcObj.getBoundingClientRect();
        return {
            x:evt.clientX - rect.left,
            y:evt.clientY - rect.top
        }
    }
};
  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

文章来源: blog.csdn.net,作者:福州-司马懿,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/chy555chy/article/details/54584985

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。