问答题912/1593怎么使用 js 实现拖拽功能?

难度:
2021-11-17 创建

参考答案:

在JavaScript中实现拖拽功能,通常需要监听几个关键的事件:mousedown(或touchstart对于移动设备)、mousemove(或touchmove)、mouseup(或touchendtouchcancel)以及mouseover(可选,用于处理元素边界外的移动)。以下是一个基本的拖拽功能的实现步骤:

1. HTML 结构

首先,你需要一个可以拖拽的元素。

1<div id="draggable" style="width: 100px; height: 100px; background-color: red; position: absolute; cursor: pointer;">拖拽我</div>

2. CSS 样式

在上面的HTML中,我已经简单设置了样式,使元素可拖动并有一个明显的背景色。

3. JavaScript 实现

接下来,我们用JavaScript来添加拖拽逻辑。

1let selected = null; // 当前被选中的拖拽元素 2let x_pos = 0; // 初始X位置 3let y_pos = 0; // 初始Y位置 4let x_elem = 0; // 鼠标按下时的X位置 5let y_elem = 0; // 鼠标按下时的Y位置 6 7// 绑定mousedown事件 8document.getElementById("draggable").addEventListener("mousedown", dragMouseDown, false); 9 10function dragMouseDown(e) { 11 e = e || window.event; 12 e.preventDefault(); // 阻止默认行为(如链接的跳转) 13 // 获取拖拽的元素 14 selected = this; 15 x_elem = x_pos = e.clientX - parseInt(selected.style.left, 10); 16 y_elem = y_pos = e.clientY - parseInt(selected.style.top, 10); 17 18 // 绑定mousemove和mouseup事件到整个文档,以便在整个页面上拖动 19 document.documentElement.addEventListener("mousemove", dragMouseMove, false); 20 document.documentElement.addEventListener("mouseup", closeDragElement, false); 21} 22 23function dragMouseMove(e) { 24 e = e || window.event; 25 e.preventDefault(); 26 // 计算新的位置 27 x_pos = e.clientX - x_elem; 28 y_pos = e.clientY - y_elem; 29 30 // 设置元素的新位置 31 selected.style.left = x_pos + "px"; 32 selected.style.top = y_pos + "px"; 33} 34 35function closeDragElement() { 36 // 停止移动时,移除mousemove和mouseup事件监听器 37 document.documentElement.removeEventListener("mousemove", dragMouseMove, false); 38 document.documentElement.removeEventListener("mouseup", closeDragElement, false); 39 selected = null; 40}

说明

  • mousedown: 当鼠标按下时,获取当前元素和鼠标相对于元素的位置。然后,将mousemovemouseup的监听器绑定到整个文档上,这样你就可以在文档的任何地方拖动元素。
  • mousemove: 当鼠标移动时,计算元素的新位置,并更新元素的样式。
  • mouseup: 当鼠标释放时,移除mousemovemouseup的监听器,避免不必要的性能消耗。

以上就是在JavaScript中实现拖拽功能的基本方法。你可以根据需要调整样式和逻辑。例如,添加拖拽的边界限制,或者支持触摸设备的拖拽等。

最近更新时间:2024-08-10

赞赏支持

预览

题库维护不易,您的支持就是我们最大的动力!