点击被多层嵌套的img(包含多层滚动条),获取基于图片的点击坐标

最近做前端界面,碰见了好多麻烦的问题,记录一下

在这里插入图片描述
像上图这样层层堆叠的窗口,在img上增加事件,点击时获取具体的坐标位置,当所有窗口都固定的时候,取出坐标点很简单

但是当浏览器body 存在滚动条,div也存在滚动条,取img的位置就容易出现偏差,
比如 我遇到的情况就是这样(把公司的东西打个码)
在这里插入图片描述
最终我的获取方法如下,供大家参考,项目太老,用的jquery做的,如果用vue做 稍作加工即可

let laserX=0 //鼠标滚动的x位置
let laserY=0 //鼠标滚动的y位置
$('.imgOuter').on('mousemove', function (e) {
            //获取鼠标位置
            laserX = e.originalEvent.x - $(this).offset().left || e.originalEvent.layerX - $(this).offset().left || 0;//
            laserY = e.originalEvent.y - $(this).offset().top || e.originalEvent.layerY - $(this).offset().top || 0;//
			//鼠标位置+滚动条
            laserX = laserX + document.documentElement.scrollLeft
            laserY = laserY + document.documentElement.scrollTop 
        })
		
		//img上绑定的click事件 获取当前鼠标点位置
        function choosePos(e) {
            let clickX = laserX 
            let clickY = laserY
        }
  • 25
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值