js實現可拖動Div

       隨着時代的變化,愈來愈感受到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;
                }
            }
        }
		

 

代碼分析:學習

  1.  

    獲取div對象this

    var $ = function (flag) {
                    return document.getElementById(flag);
                }     對象

  2. 捕捉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);
                    }

    這個就是捕捉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,後續有新的心得體會也會與你們分享,但願與你們共同窗習,進步。

相關文章
相關標籤/搜索