

现在切入正题,说一下js 实现可拖动Div.实现这个功能我们先说一下思路:
1.捕捉鼠标div的mousedown事件
2.捕捉 document的 mousemove事件
3.取消事件
然后我们看一下代码:
 代码如下:
function Drag(id) {
 var $ = function (flag) {
 return document.getElementById(flag);
 }
 $(id).onmousedown = function (e) {
 var d = document;
 var page = {
 event: function (evt) {
 var ev = evt || window.event;
 return ev;
 },
 pageX: function (evt) {
 var e = this.event(evt);
 return e.pageX || (e.clientX + document.body.scrollLeft - document.body.clientLeft);
 },
 pageY: function (evt) {
 var e = this.event(evt);
 return e.pageY || (e.clientY + document.body.scrollTop - document.body.clientTop);
 },
 layerX: function (evt) {
 var e = this.event(evt);
 return e.layerX || e.offsetX;
 },
 layerY: function (evt) {
 var e = this.event(evt);
 return e.layerY || e.offsetY;
 }
 } 
 var x = page.layerX(e);
 var y = page.layerY(e); 
 if (dv.setCapture) {
 dv.setCapture();
 }
 else if (window.captureEvents) {
 window.captureEvents(Event.MOUSEMOVE | Event.MOUSEUP);
 }
 d.onmousemove = function (e) { 
 var tx = page.pageX(e) - x;
 var ty = page.pageY(e) - y;
 dv.style.left = tx + "px";
 dv.style.top = ty + "px";
 }
 d.onmouseup = function () {
 if (dv.releaseCapture) {
 dv.releaseCapture();
 }
 else if (window.releaseEvents) {
 window.releaseEvents(Event.MOUSEMOVE | Event.MOUSEUP);
 }
 d.onmousemove = null;
 d.onmouseup = null;
 }
 }
 }
代码分析:
1.
获取div对象
 代码如下:
var $ = function (flag) {
 return document.getElementById(flag);
 } 
2.捕捉document的mousedown事件:
里面有这么一段代码:
 代码如下:
 var page = {
 event: function (evt) {
 var ev = evt || window.event;
 return ev;
 },
 pageX: function (evt) {
 var e = this.event(evt);
 return e.pageX || (e.clientX + document.body.scrollLeft - document.body.clientLeft);
 },
 pageY: function (evt) {
 var e = this.event(evt);
 return e.pageY || (e.clientY + document.body.scrollTop - document.body.clientTop);
 },
 layerX: function (evt) {
 var e = this.event(evt);
 return e.layerX || e.offsetX;
 },
 layerY: function (evt) {
 var e = this.event(evt);
 return e.layerY || e.offsetY;
 }
 } 
其中event获取鼠标事件,pageX,pageY获取鼠标的坐标,layerX,layerY获取鼠标距离div边框的距离。
还有一段代码:
 代码如下:
 if (dv.setCapture) {
 dv.setCapture();
 }
 else if (window.captureEvents) {
 window.captureEvents(Event.MOUSEMOVE | Event.MOUSEUP);
 }
这个就是捕捉div的MouseMove和MouseUp事件,不懂得tx可以到网上查查。
3. document的MouseMove和mouseUp事件: 
 代码如下:
d.onmousemove = function (e) { 
 var tx = page.pageX(e) - x;
 var ty = page.pageY(e) - y;
 dv.style.left = tx + "px";
 dv.style.top = ty + "px";
 } 
 d.onmouseup = function () {
 if (dv.releaseCapture) {
 dv.releaseCapture();
 }
 else if (window.releaseEvents) {
 window.releaseEvents(Event.MOUSEMOVE | Event.MOUSEUP);
 }
 d.onmousemove = null;
 d.onmouseup = null;
 }
其中的tx,ty就是最重要的代码了,是设置div坐标的
有的人可能会问为什么要-x,-y?
x,y其实就是获取鼠标距离div边框的距离,如果不减掉的话
鼠标箭头的坐标和div的x,y坐标一样了,这样拖动之后,鼠标的位置会偏到左上角,效果就是,拖动之后会弹动一下。
 代码如下:
 if (dv.releaseCapture) {
 dv.releaseCapture();
 }
 else if (window.releaseEvents) {
 window.releaseEvents(Event.MOUSEMOVE | Event.MOUSEUP);
 }
 d.onmousemove = null;
 d.onmouseup = null;
上面这段代码就是在鼠标松开之后取消document的onmousemove,onmouseup事件。
最近都在学习js,后续有新的心得体会也会与大家分享,希望与大家共同学习,进步。
