JS拖拽div(移动)

素颜马尾好姑娘i 2023-06-30 02:20 117阅读 0赞

//获取元素
var dv = document.getElementById(‘dv’);
var x = 0;
var y = 0;
var l = 0;
var t = 0;
var isDown = false;
//鼠标按下事件
dv.onmousedown = function(e) {
//获取x坐标和y坐标
x = e.clientX;
y = e.clientY;

  1. //获取左部和顶部的偏移量
  2. l = dv.offsetLeft;
  3. t = dv.offsetTop;
  4. //开关打开
  5. isDown = true;
  6. //设置样式
  7. dv.style.cursor = 'move';

}
//鼠标移动
window.onmousemove = function(e) {
if (isDown == false) {
return;
}
//获取x和y
var nx = e.clientX;
var ny = e.clientY;
//计算移动后的左偏移量和顶部的偏移量
var nl = nx - (x - l);
var nt = ny - (y - t);

  1. dv.style.left = nl + 'px';
  2. dv.style.top = nt + 'px';

}
//鼠标抬起事件
dv.onmouseup = function() {
//开关关闭
isDown = false;
dv.style.cursor = ‘default’;
}

发表评论

表情:
评论列表 (有 0 条评论,117人围观)

还没有评论,来说两句吧...

相关阅读

    相关 JS

    实现后效果 ![70][] 实现原理: 1. 在允许拖拽的节点元素上,监听mousedown(按下鼠标按钮)事件,鼠标按下后,事件触发 2. 监听mousemov