为了账号安全,请及时绑定邮箱和手机立即绑定

js中如何区分鼠标的点击事件和滑动事件?

js中如何区分鼠标的点击事件和滑动事件?

墨色风雨 2018-10-16 21:22:43
各位大神, 我是想用网页做一个画板,有像photoshop类似的图层效果,可以改变图层之间的覆盖关系。构建图层的函数已经封装好了。但是我现在想区分如果鼠标只是点击click时,不增加图层。但是在用画笔划线滑动时,构建图层。如果把事件绑定在onmouseover上,就会一移动鼠标就构建。绑在onmouseup上点击时也会加图层。大神们有什么解决办法吗?
查看完整描述

1 回答

?
暮色呼如

TA贡献1853条经验 获得超9个赞

点下鼠标后,记录此时鼠标的clientX和clientY,
放开鼠标后,看clientX和clientY与原先是否相同,即可。
如果想要移动一小点也算点击,则设个范围比较

var Mouse = {

    x: 0,

    y: 0,

    mousedown: function (event) {

        Mouse.y = event.clientY;

        Mouse.x = event.clientX;

    },

    mouseup: function (event) {

        if (event.clientX != Mouse.x || event.clientY != Mouse.y) {

            console.log('slide');

        } else {

            console.log('click');

        }

    }

}

document.body.onmousedown = Mouse.mousedown;

document.body.onmouseup = Mouse.mouseup;


查看完整回答
反对 回复 2018-11-26
  • 1 回答
  • 0 关注
  • 2357 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信