隨着時代的變化,愈來愈感受到js的重要性,js不只能夠作web頁面(如Ext框架),還能夠作一些web的特效,這些特效不只兼容PC,並且兼容手機端,畢竟是基於瀏覽器的,和平臺不要緊。如今微軟的windows8 系統的App均可以用js開發了,你們有時間能夠去嘗試一下。javascript
如今切入正題,說一下js 實現可拖動Div.實現這個功能咱們先說一下思路:java
1.捕捉鼠標div的mousedown事件web
2.捕捉 document的 mousemove事件windows
3.取消事件瀏覽器
而後咱們看一下代碼:框架
function Drag(id) { var $ = function (flag) { return document.getElementById(flag); } $(id).onmousedown = function (e) { var d = document; var that=this; 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 (that.setCapture) { that.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; that.style.left = tx + "px"; that.style.top = ty + "px"; } d.onmouseup = function () { if (that.releaseCapture) { that.releaseCapture(); } else if (window.releaseEvents) { window.releaseEvents(Event.MOUSEMOVE | Event.MOUSEUP); } d.onmousemove = null; d.onmouseup = null; } } }
代碼分析:學習
獲取div對象this
var $ = function (flag) {
return document.getElementById(flag);
} 對象
捕捉document的mousedown事件:blog
裏面有這麼一段代碼:
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);
}
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,後續有新的心得體會也會與你們分享,但願與你們共同窗習,進步。