js 区分鼠标是点击事件还是拖拽事件,以及canvas拖拽

在使用jsMind思维导图插件的时候需要对整个canvas进行拖拽,通过对源码的解读,摸索出这个方式,写下大概的思路,完整的jsMinddemo见gitHUb:https://github.com/Hongmy0/jsMind-.git

<!DOCTYPE html>
<html>

	 <head>
		<meta charset="UTF-8">
		<title>jsMind</title>
		
	 </head>

	 <body>
	
		<canvas id="can" onclick=“click()”></canvas >
	 </body>

<script>
var draging = false;// 用来区分的标记位
var clickFlag = false; 点击事件的flag
var timmerHandle = null;
function setDragTrue()
  {
    draging = true;
  }
$('body').on({
	'mousedown': function(e) {
        //每次点击都会触发
	draging = false;
	var el = e.target ||  event.srcElement;				
	oldPositon.x = e.clientX - el.offsetLeft;
	oldPositon.y = e.clientY - el.offsetTop;
	// 区分是点击还是拖拽事件 延时200毫秒
	timmerHandle = setTimeout(setDragTrue,200);
	},
	'mouseup': function(e) {
		if(!draging){
			// 清除定时器,避免200毫秒后一直在调用
			clearTimeout(timmerHandle); 
		}else{
			draging = false;
		    }
		},
        'mousemove': function(){
	   if(!draging||!clickFlag) {
		return
	   }
	  var drag = $('#can');
	  var el = e.target || event.srcElement;
	  var px = e.clientX - oldPositon.x;
          var py = e.clientY - oldPositon.x;
	  drag.css({
	      position: 'absolute',
	      left: px,
	      top: py
           });
         }
    });
   function click(e) {
	clickFlag = true;
			
   }

</script>
</html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值