可以拖动的div 实现代码第1/2页

时间:2024-03-19 17:46:20 

要实现div的任意拖动,我们不妨分析一下整个过程。
当鼠标点击div时,触发一个事件,让div的位置属性(left,top)随着鼠标位置变化而变化,当鼠标释放后,div的位置属性就用了鼠标释放时的位置。
鼠标点击时触发事件是很容易做到的,只要在div的标签里加上onmouseclick就可以了,现在我们要解决的问题是如何让div的位置随着鼠标的位置变化而变化。
虽然这可能是一个很简单的推理过程,不过还是罗嗦点说清楚吧。div的left和top是div左上角的坐标,当我们把鼠标移到div中点击的时候,无疑鼠标的坐标和div的坐标是不一致的,这时候如果我们简单的让div的坐标等于鼠标的坐标,那么看起来的效果就不是那么完美了,所以我们先要得到鼠标的坐标和div坐标的差,然后在鼠标移动到的时候,在鼠标坐标上减去这个差来得到div的坐标(如果不太明白,那就先补习一下网页的基础知识)。
接下来的事情就简单了,当鼠标移动的时候,我们不断的计算得到div的坐标,并改变,在鼠标释放的时候,这个事件就被移除。
整个js函数如下:
function beginDrag(elementToDrag,event)
{
var deltaX=event.clientX-parseInt(elementToDrag.style.left);
var deltaY=event.clientY-parseInt(elementToDrag.style.top);
if(document.addEventListener)
{
document.addEventListener(”mousemove”,moveHandler,true);
document.addEventListener(”mouseup”,upHandler,true);
//document.addEventListener(”mouseout”,upHandler,true);
}
else if(document.attachEvent)
{
document.attachEvent(”onmousemove”,moveHandler);
document.attachEvent(”onmouseup”,upHandler);
//document.attachEvent(”onmouseout”,upHandler);
}
if(event.stopPropagation) event.stopPropagation();
else event.cancelBubble=true;
if(event.preventDefault) event.preventDefault();
else event.returnValue=false;
function moveHandler(e)
{
if (!e) e=window.event; //如果是IE的事件对象,那么就用window.event
//全局属性,否则就用DOM二级标准的Event对象。
elementToDrag.style.left=(e.clientX-deltaX)+”px”;
elementToDrag.style.top=(e.clientY-deltaY)+”px”;
if(e.stopPropagation) e.stopPropagation();
else e.cancelBubble=true;
}
function upHandler(e)
{
if(document.removeEventListener)
{
document.removeEventListener(”mouseup”,upHandler,true);
document.removeEventListener(”mousemove”,moveHandler,true);}
else
{
document.detachEvent(”onmouseup”,upHandler);
document.detachEvent(”onmousemove”,moveHandler);}
}
if (!e) e=window.event;
if(e.stopPropagation) e.stopPropagation();
else e.cancelBubble=true;
}                      

标签:拖动,div
0
投稿

猜你喜欢

  • centos7下mysql5.6的主从复制详解

    2024-01-18 03:52:21
  • Django Form设置文本框为readonly操作

    2023-11-11 03:03:43
  • 如何提升JavaScript的运行速度(函数篇)

    2010-05-17 13:27:00
  • Python作用域用法实例详解

    2022-12-10 15:44:42
  • jQuery代码的14条改善技巧[译]

    2009-12-02 10:02:00
  • MySQL redo死锁问题排查及解决过程分析

    2024-01-17 08:17:02
  • PyTorch搭建LSTM实现多变量时序负荷预测

    2023-10-29 10:48:50
  • Python正则表达式re模块详解(建议收藏!)

    2022-07-28 04:52:46
  • PHP PDOStatement::bindColumn讲解

    2023-06-10 04:35:55
  • Python之日期与时间处理模块(date和datetime)

    2023-09-29 12:53:06
  • PHP简单预防sql注入的方法

    2024-06-07 15:50:25
  • 从0到1搭建后端架构的演进(MVC,服务拆分,微服务,领域驱动)

    2022-04-24 10:03:35
  • HTML的基本元素

    2010-03-16 12:39:00
  • Vue 页面监听用户预览时间功能的实现代码

    2024-04-27 15:56:25
  • chatGPT本地部署、运行和接口调用的详细步骤

    2023-08-31 03:46:31
  • 模拟jQuery中的ready方法及实现按需加载css,js实例代码

    2024-04-22 22:20:39
  • python @property 装饰器使用方法

    2021-04-01 00:38:05
  • mysql limit 分页的用法及注意要点

    2024-01-21 06:44:50
  • JS中dom0级事件和dom2级事件的区别介绍

    2024-04-16 09:31:41
  • python下读取公私钥做加解密实例详解

    2022-04-17 03:39:00
  • asp之家 网络编程 m.aspxhome.com