zoukankan      html  css  js  c++  java
  • 区分拖曳(drag)和点击(click)事件

    假设页面上有一个a标签:

    <a href="http://www.google.com">google</a>

    现在需要对这个标签进行拖放操作,会发现当拖曳完成后,该链接也同时被打开了,这并不是期望的结果,因为我们仅仅想将这个标签拖放到另一个位置而已。

    最初很自然地想到了用preventDefault来阻止默认行为,可实际操作后发现这种方案不可行。

    由于拖曳需要监听三个事件:mousedown、mousemove、mouseup,而点击事件click则包含了mousedown和mouseup,如果阻止了默认的click操作,那么

    拖曳也不能正常进行。解决这个问题的关键是区分鼠标是点击还是拖曳,下面是解决方案,为精简代码,用到了jQuery:

    var a = $('a'),
          flag = 0;    //标记是拖曳还是点击
    
    a.bind({
        mousedown:function(e) {
            flag = 0;
            //code...
        },
        mousemove:function(e) {
            flag = 1;
            //code...
        },
        mouseup:function(e) {
            if(flag === 0) {//点击
                a.unbind();
            } else if(flag === 1) {//拖曳
                a.bind('click',function(){
                    return false; //阻止默认行为
                });
            }
            //code...
        }
    });

    通过一个flag变量来区分是点击还是拖曳操作,这样拖曳和点击链接就不冲突了。

  • 相关阅读:
    luogu P3239 [HNOI2015]亚瑟王
    android之软件键盘
    Eclipse输入智能提示设置
    防止反编译
    二进制数据读写
    数据类型转换
    类对象的读写文件
    Eclipse 快捷键
    修改IP
    Android eclipse 运行项目设置程序默认安装到SD卡
  • 原文地址:https://www.cnblogs.com/undefined000/p/click-and-drag.html
Copyright © 2011-2022 走看看