拖拽原理以及代码实现

Posted 执着的小猪仔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了拖拽原理以及代码实现相关的知识,希望对你有一定的参考价值。

拖拽功能主要是用在让用户做一些自定义的动作,比如拖动排序,弹出框拖动移动等等;挺好玩儿,和码友们一起学习!理解有误或者有更好的建议请提出来哦

下面分享一下拖拽的原理

拖拽流程:

1)事件:onmousedown;onmousemove;onmouseup;

2)实现原理分析:

拖拽是通过获取鼠标移动的距离来实现的,即计算移动前的位置的坐标(x,y)与移动中的位置的坐标(x,y)差值。
当onmousedown或onmousemove时,都可以获取到当前鼠标的位置,即移动前的坐标值与移动中的坐标值。
参考如下图:

如上图所示:

在onmousemove中元素的left值为 : 鼠标移动后的left值 - 鼠标按下的left值 + 元素的初始left值;
       top值为 : 鼠标移动后的top值 - 鼠标按下的top值 + 元素的初始top值;

需要注意:onmousemove;onmouseup事件要在onmousedown事件内;

代码如下:

 1  function drag(id,Range){
 2  var _this=this;
 3  if (Range==void(0))Range=document;
 4  var obox=document.getElementById(id);
 5  obox.onmousedown=function(e){
 6  fndown(e,this,Range);
 7  //兼容IE事件捕获点下之后进行获取事件;setcapture事件捕获和releaseCapture释放事件捕获要成对出现使用;用于解决IE不能阻止默认事件问题;
 8  //当进行拖拽的时候图片也会有默认事件;用同样的方法进行阻止默认事件;
 9  if (this.setcapture) {
10  this.setcapture()
11  }
12  return false;
13  
14  
15  }
16  },
17  
18  /*******************************
19  当鼠标按下后obj的left和top值设置为鼠标的X轴和Y轴;
20  当进行拖动时设置元素的left值和top值实现拖拽
21  
22  ************************************************/
23  function  fndown(e,obj,Range){
24  if(Range!=document) Range=document.getElementById(Range);
25  var e=e||window.event;
26  this.ledt=e.clientX-obj.offsetLeft;
27  this.ledr=e.clientY-obj.offsetTop;
28  Range.onmousemove=function(e){
29  var rangeW=Range==document?document.documentElement.clientWidth:fan.offsetWidth;
30  var rangeH=Range==document?document.documentElement.clientHeight:fan.offsetHeight
31  var e=e||window.event;
32  var ollL=e.clientX-this.ledt;
33  var ollR=e.clientY-this.ledt;
34  if(ollL<0)ollL=0;
35  if(ollL>rangeW-obj.offsetWidth){
36  ollL=parseInt(rangeW-obj.offsetWidth);
37  }
38 if(ollR<0)ollR=0;
39  if(ollR>rangeH-obj.offsetHeight){
40  ollR=parseInt(rangeH-obj.offsetHeight);
41  }
42  obj.style.left=ollL+\'px\';
43  obj.style.top=ollR+\'px\';
44  }.bind(this);
45  Range.onmouseup=function(){
46  this.onmousemove=this.onmouseup=null;
47  
48  //当鼠标抬起之后释放事件捕获
49  if (obj.releaseCapture) {
50  obj.releaseCapture()
51  }
52 
53 };
54  }

 

以上是关于拖拽原理以及代码实现的主要内容,如果未能解决你的问题,请参考以下文章

JS拖拽元素原理及实现代码

javascript动画系列第一篇——模拟拖拽

鼠标拖拽元素以及继承原生代码

基于Vue实现拖拽升级(九宫格拖拽)

二级域名原理以及程序代码

可视化拖拽组件库一些技术要点原理分析