方案一:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">  

<head runat="server">  

    <title></title>  

    <script type="text/javascript">  

        var mouseX, mouseY;  

        var objX, objY;  

        var isDowm = false;  //是否按下鼠标  

        function mouseDown(obj, e) {  

            obj.style.cursor = "move";  

            objX = div1.style.left;  

            objY = div1.style.top;  

            mouseX = e.clientX;  

            mouseY = e.clientY;  

            isDowm = true;  

        }  

        function mouseMove(e) {  

            var div = document.getElementById("div1");  

            var x = e.clientX;  

            var y = e.clientY;  

            if (isDowm) {  

                div.style.left = parseInt(objX) + parseInt(x) - parseInt(mouseX) + "px";  

                div.style.top = parseInt(objY) + parseInt(y) - parseInt(mouseY) + "px";  

                document.getElementById("span1").innerHTML = "x:" + div.style.top + "  " + "y:" + div.style.left;  

            }  

        }  

        function mouseUp(e) {  

            if (isDowm) {  

                var x = e.clientX;  

                var y = e.clientY;  

                var div = document.getElementById("div1");  

                div.style.left = (parseInt(x) - parseInt(mouseX) + parseInt(objX)) + "px";  

                div.style.top = (parseInt(y) - parseInt(mouseY) + parseInt(objY)) + "px";  

                document.getElementById("span2").innerHTML = "x:" + div.style.top + "  " + "y:" + div.style.left;  

                mouseX = x;  

                rewmouseY = y;  

                div1.style.cursor = "default";  

                isDowm = false;  

            }  

        }  

    </script>  

</head>  

<body>  

    <span id="span1"></span></br><span id="span2"></span></br>  

    <div id="div1" style="background-color: Green; border: 1px solid red; height: 300px;  

        top: 100px; left: 100px; width: 300px; position: absolute;" onmousedown="mouseDown(this,event)"  

        onmousemove="mouseMove(event)" onmouseup="mouseUp(event)">  

    </div>  

</body>

</html>

方案二:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>拖拽库</title>

<style type="text/css">

div,h2,p{margin:0;padding:0;}

body{font:14px/1.5 arial;}

#box{width:100px;height:100px;background:#fef4eb;padding:5px;margin:50px;border:1px solid #f60;}

#box .title{height:25px;background:#f60;}

#tool{margin-bottom:10px;}

</style>

<script type="text/javascript">

function Drag()

{

 //初始化

 this.initialize.apply(this, arguments)

}

Drag.prototype = {

 //初始化

 initialize : function (drag, options)

 {

  this.drag = this.$(drag);

  this._x = this._y = 0;

  this._moveDrag = this.bind(this, this.moveDrag);

  this._stopDrag = this.bind(this, this.stopDrag);



  this.setOptions(options);



  this.handle = this.$(this.options.handle);

  this.maxContainer = this.$(this.options.maxContainer);



  this.maxTop = Math.max(this.maxContainer.clientHeight, this.maxContainer.scrollHeight) - this.drag.offsetHeight;

  this.maxLeft = Math.max(this.maxContainer.clientWidth, this.maxContainer.scrollWidth) - this.drag.offsetWidth;



  this.limit = this.options.limit;

  this.lockX = this.options.lockX;

  this.lockY = this.options.lockY;

  this.lock = this.options.lock;



  this.onStart = this.options.onStart;

  this.onMove = this.options.onMove;

  this.onStop = this.options.onStop;



  this.handle.style.cursor = "move";



  this.changeLayout();



  this.addHandler(this.handle, "mousedown", this.bind(this, this.startDrag))

 },

 changeLayout : function ()

 {

  this.drag.style.top = this.drag.offsetTop + "px";

  this.drag.style.left = this.drag.offsetLeft + "px";

  this.drag.style.position = "absolute";

  this.drag.style.margin = "0"

 },

 startDrag : function (event)

 {  

  var event = event || window.event;



  this._x = event.clientX - this.drag.offsetLeft;

  this._y = event.clientY - this.drag.offsetTop;



  this.addHandler(document, "mousemove", this._moveDrag);

  this.addHandler(document, "mouseup", this._stopDrag);



  event.preventDefault && event.preventDefault();

  this.handle.setCapture && this.handle.setCapture();



  this.onStart()

 },

 moveDrag : function (event)

 {

  var event = event || window.event;



  var iTop = event.clientY - this._y;

  var iLeft = event.clientX - this._x;



  if (this.lock) return;



  this.limit && (iTop < 0 && (iTop = 0), iLeft < 0 && (iLeft = 0), iTop > this.maxTop && (iTop = this.maxTop), iLeft > this.maxLeft && (iLeft = this.maxLeft));



  this.lockY || (this.drag.style.top = iTop + "px");

  this.lockX || (this.drag.style.left = iLeft + "px");



  event.preventDefault && event.preventDefault();



  this.onMove()

 },

 stopDrag : function ()

 {

  this.removeHandler(document, "mousemove", this._moveDrag);

  this.removeHandler(document, "mouseup", this._stopDrag);



  this.handle.releaseCapture && this.handle.releaseCapture();



  this.onStop()

 },

 //參数设置

 setOptions : function (options)

 {

  this.options =

  {

   handle:   this.drag, //事件对象

   limit:   true, //锁定范围

   lock:   false, //锁定位置

   lockX:   false, //锁定水平位置

   lockY:   false, //锁定垂直位置

   maxContainer: document.documentElement || document.body, //指定限制容器

   onStart:  function () {}, //開始时回调函数

   onMove:   function () {}, //拖拽时回调函数

   onStop:   function () {}  //停止时回调函数

  };

  for (var p in options) this.options[p] = options[p]

 },

 //获取id

 $ : function (id)

 {

  return typeof id === "string" ? document.getElementById(id) : id

 },

 //加入绑定事件

 addHandler : function (oElement, sEventType, fnHandler)

 {

  return oElement.addEventListener ? oElement.addEventListener(sEventType, fnHandler, false) : oElement.attachEvent("on" + sEventType, fnHandler)

 },

 //删除绑定事件

 removeHandler : function (oElement, sEventType, fnHandler)

 {

  return oElement.removeEventListener ?

oElement.removeEventListener(sEventType, fnHandler, false) : oElement.detachEvent("on" + sEventType, fnHandler)

 },

 //绑定事件到对象

 bind : function (object, fnHandler)

 {

  return function ()

  {

   return fnHandler.apply(object, arguments) 

  }

 }

};

//应用

window.onload = function ()

{

 var oBox = document.getElementById("box"); 

 var oTitle = oBox.getElementsByTagName("h2")[0];

 var oSpan = document.getElementsByTagName("span")[0];

 var oDrag = new Drag(oBox, {handle:oTitle, limit:false});



 var aInput = document.getElementsByTagName("input");



 //锁定范围接口

 aInput[0].onclick = function ()

 {

  oDrag.limit = !oDrag.limit;

  this.value = oDrag.limit ? "取消锁定范围" : "锁定范围"

 };



 //水平锁定接口

 aInput[1].onclick = function ()

 {

  oDrag.lockX = !oDrag.lockX;

  this.value = oDrag.lockX ? "取消水平锁定" : "水平锁定"

 };



 //垂直锁定接口

 aInput[2].onclick = function ()

 {

  oDrag.lockY = !oDrag.lockY;

  this.value = oDrag.lockY ? "取消垂直锁定" : "垂直锁定"

 };



 //锁定位置接口

 aInput[3].onclick = function ()

 {

  oDrag.lock = !oDrag.lock;

  this.value = oDrag.lock ? "取消锁定位置" : "锁定位置"

 };



 //開始拖拽时方法

 oDrag.onStart = function ()

 {

  oSpan.innerHTML = "開始拖拽" 

 };



 //開始拖拽时方法

 oDrag.onMove = function ()

 {

  oSpan.innerHTML = "left:" + this.drag.offsetLeft + ", top:" + this.drag.offsetTop 

 };



 //開始拖拽时方法

 oDrag.onStop = function ()

 {

  oSpan.innerHTML = "结束拖拽" 

 };

};

</script>

</head>

<body>

<div id="tool">

 <input type="button" value="锁定范围" />

    <input type="button" value="水平锁定" />

    <input type="button" value="垂直锁定" />

    <input type="button" value="锁定位置" />

</div>

<p>拖放状态:<span>未開始</span></p>

<div id="box">

 <h2 class="title"></h2>

</div>

</body>

</html>

</td>

   </tr>

 </table>

js完美的div拖拽实例代码的更多相关文章

  1. 纯js实现DIV拖拽

    写代码的时候遇到需要对绝对布局的div进行拖拽的功能,起初为了省事直接在网上扒拉了一番,看到大神张鑫旭的一篇文章<JavaScript实现最简单的拖拽效果>,便直接拿来使用(膜拜大神).但 ...

  2. js div浮动层拖拽效果代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. html js点击按钮滚动跳转定位到页面指定位置(DIV)的方法代码

    一:通过html锚点实现滚动定位到页面指定位置(DIV):    如果我们要点击实现跳转的地方是一个html锚点,也就是点击一个A标签超链接实现跳转,可以把A标签的href属性直接指向跳转指定位置的d ...

  4. js/jquery/html前端开发常用到代码片段

    1.IE条件注释 条件注释简介 IE中的条件注释(Conditional comments)对IE的版本和IE非IE有优秀的区分能力,是WEB设计中常用的hack方法.条件注释只能用于IE5以上,IE ...

  5. 通过 JS 实现简单的拖拽功能并且可以在特定元素上禁止拖拽

    前言 关于讲解 JS 的拖拽功能的文章数不胜数,我确实没有必要大费周章再写一篇重复的文章来吸引眼球.本文的重点是讲解如何在某些特定的元素上禁止拖拽.这是我在编写插件时遇到的问题,其实很多插件的拖拽功能 ...

  6. div+css通用兼容性代码整理

    一.Div+css通用兼容性代码 你可以在css开头加入 *html{padding:0px} <style> *html{padding:0px} /* Clear Fix */ .cl ...

  7. 运用DIV拖拽实现resize和碰撞检测

    运用DIV拖拽实现resize和碰撞检测 Div由拖拽改变大小 演示demo 当我们运用html元素"textarea"写一个文本输入框时,浏览器会自动生成以下样式 用鼠标拖动右下 ...

  8. ECharts组件应用样例代码

    一.从Echarts官网上下载最新版本组件 Echarts是百度开发的开源Web图表组件,界面美观,使用简单.组件下载地址:http://echarts.baidu.com/echarts2/doc/ ...

  9. js实现拉伸拖动iframe的具体代码

    这篇文章介绍了js实现拉伸拖动iframe的具体代码,有需要的朋友可以参考一下左边iframe放树目录,右边的iframe放index页.拖鼠标同时控制2个iframe的宽高.期待有人能改进.操作方法 ...

随机推荐

  1. 【BZOJ2662】【BeiJing wc2012】冻结 分层图 裸的!

    我都不好意思发题解了,看这篇博吧.(飞行路线的,基本一样) http://blog.csdn.net/vmurder/article/details/40075989 同学做了好久.我害怕题里有坑,又 ...

  2. [置顶] IOS用CGContextRef画各种图形(文字、圆、直线、弧线、矩形、扇形、椭圆、三角形、圆角矩形、贝塞尔曲线、图片)

    首先了解一下CGContextRef: An opaque type that represents a Quartz 2D drawing environment. Graphics Context ...

  3. MySQL 动态sql语句运行 用时间做表名

    1. 描写叙述 在使用数据的时候,我时候我们须要非常多数据库,并且想用时间来做表名以区分.可是MySQL在存储过程中不支持使用变量名来做表名或者列名. 比方,有一个表我们想以"2015-07 ...

  4. oauth2-server-php for windows 的那些坑 (研究中...)

    oauth2-server-php for windows 的那些坑 在windwos 环境下,使用vs2017 for php 工具进行调试时,总是搞不出来, 于是分析了一下原因, 首先,oauth ...

  5. [Node.js] Availability and Zero-downtime Restarts

    It might be possible for our node server has some downtime, no matter it is because server update or ...

  6. GG配置ggmgr进程

    Oracle配置mgr进程 edit params mgr port 7809 syslog none dynamicportlist 7810-7820 自己主动会生成./dirprm/mgr.pr ...

  7. (转)解决 bitmap size exceeds VM budget (Out Of Memory 内存溢出)的问题

    在做图片处理的时候最常遇到的问题估计就是Out Of Memory (内存溢出)了 网上对这种问题的解决方案很多,原来无非就是压缩图片大小 本不该重复造轮子,但实际中却遇见了问题,写出来希望后来者能引 ...

  8. vscode - 设置中文语言

    记得上次安装的时候,自动提示安装本地语言包,现在的版本貌似不会了吧. 1.先安装扩展,按键CTRL+SHIFT+P 输入 ext install ,最后输入:language,大概就可以找到简体中文包 ...

  9. Hibernate(十二)Criteria查询

    一.简述 Criteria是一种比hql更面向对象的查询方式.Criteria 可使用 Criterion 和 Projection 设置查询条件.可以设置 FetchMode(联合查询抓取的模式 ) ...

  10. Jsp之神笔记

    JSP笔记 Tomcatserver port: port就是指的某一个程序网络入口,Tomcat的初始化port为:8080: port的个数:256*256=65536个: 一般常见协议的缺省po ...