# 手写拖拽

window.onload = function() {
  //获取元素需要绝对定位
  let drag = document.getElementById("drag");
  drag.onmousedown = function(e) {
    var e = e || window.event;
    //鼠标与拖拽元素边界的距离 = 鼠标与可视区边界的距离 - 拖拽元素与边界的距离
    let diffX = e.clientX - drag.offsetLeft;
    let diffY = e.clientY - drag.offsetTop;
    drag.onmousemove = function(e) {
      //拖拽元素的left/top = 鼠标与可视边界的距离 - 鼠标与拖拽元素边界的距离
      let left = e.clientX - diffX;
      let top = e.clientY - diffY;
      //避免拖拽出可视区
      if(left < 0){
        left = 0;
      }else if(left > window.innerWidth - drag.offsetWidth){
        left = window.innerWidth - drag.offsetWidth;
      }
      if(top < 0){
        top = 0;
      }else if(top > window.innerHeight - drag.offsetHeight){
        top = window.innerHeight - drag.offsetHeight;
      }
      drag.style.left = left + "px";
      drag.style.top = top + "px";
    };
    drag.onmouseup = function(e){
      this.onmousemove = null;
      this.onmouseup = null;
    }
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
Last Updated: 1/22/2022, 6:01:48 PM