麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

js實現可拖動DIV的方法

2019-11-20 21:26:37
字體:
來源:轉載
供稿:網友

隨著時代的變化,越來越感覺到js的重要性,js不僅可以做web頁面(如Ext框架),還可以做一些web的特效,這些特效不僅兼容PC,而且兼容手機端,畢竟是基于瀏覽器的,和平臺沒關系。現在微軟的windows8 系統的App都可以用js開發了,大家有時間可以去嘗試一下。

     現在切入正題,說一下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,后續有新的心得體會也會與大家分享,希望與大家共同學習,進步。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品视频免费在线观看 | 黄色一级片免费在线观看 | 免费一级欧美在线观看视频 | 无码专区aaaaaa免费视频 | 欧美一级特级 | 久久宗合色| 久久综合狠狠综合久久 | 福利在线小视频 | 麻豆小视频在线观看 | 九一传媒在线观看 | 逼片| 最新一区二区三区 | 婷婷久久久久久 | 亚洲国产高清自拍 | 亚洲国产精品久久久久久久久久 | 久久网一区二区 | 线观看免费完整aaa 一二区成人影院电影网 | 在线观看免费精品 | 成人福利软件 | 爱福利视频 | 国产98色 | 国产精品久久久久久久久久久久久久久久 | 双性精h调教灌尿打屁股的文案 | 欧美成年人在线视频 | 成人精品| 国产成人精品自拍视频 | 久久线视频 | 3344永久免费 | 看免费一级毛片 | 久久精品视频69 | 欧洲成人综合网 | 久久精品欧美电影 | 精品一区二区在线观看 | 美国av免费看 | 成人毛片视频免费 | 久久人人爽人人爽人人片av免费 | 91婷婷射 | 一区国产在线观看 | 亚洲爱爱网站 | 最新欧美精品一区二区三区 | 成人在线免费观看视频 |