# 手写拖拽
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
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