亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

原生javascript實現拖動元素示例代碼

2019-11-20 14:13:27
字體:
來源:轉載
供稿:網友

本文介紹原生javascript實現元素拖動。

思路:

1.首先改變被拖動元素的布局屬性,關鍵是“position:absolue”;

2.捕捉鼠標事件"mousedown","mousemove","mouseup";

3.當觸發"mousedown"時,記錄下當前鼠標在元素中的相對位置,_x,_y;

4.緊接著處理"mousemove"事件,通過改變元素的top和left屬性來移動元素;

5.當觸發"mouseup"時間時,終止拖動。

同時,應考慮代碼的封裝性和瀏覽器的兼容性,代碼如下:

<!DOCTYPE html> <html> <head> <title>draggable div</title> <style type="text/css"> body{ margin: 0; padding: 0; background-color: #fff; } #drag_div{ width: 150px; height: 150px; padding: 10px; margin: 10px; background-color: #66dd33; cursor: move; } </style> </head> </html> <body> <div id="drag_div"></div> </body> <script type="text/javascript"> function Drag () { this.initialize.apply(this, arguments); } Drag.prototype = { // 初始化 initialize : function (element, options) { this.element = this.$(element); // 被拖動的對象 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.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.element.style.top = this.element.offsetTop + "px"; this.element.style.left = this.element.offsetLeft + "px"; this.element.style.position = "absolute"; this.element.style.margin = "0"; }, startDrag : function (event) { var event = event || window.event; this._x = event.clientX - this.element.offsetLeft; this._y = event.clientY - this.element.offsetTop; this.addHandler(document, "mousemove", this._moveDrag); this.addHandler(document, "mouseup", this._stopDrag); this.preventDefault(event); this.handle.setCapture && this.handle.setCapture(); this.onStart(); }, moveDrag : function (event) { var event = this.getEvent(event); var iTop = event.clientY - this._y; var iLeft = event.clientX - this._x; this.element.style.top = iTop + "px"; this.element.style.left = iLeft + "px"; 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.element, //事件對象 onStart : function () {}, // 開始時回調函數 onMove : function(){}, // 拖拽時回調函數 onStop : function(){} // 停止時回調函數 }; for(var p in options){ this.options[p] = options[p]; } }, $ : function (id) { return typeof id === "string" ? document.getElementById(id):id; }, addHandler : function (element, eventType, handler) { if(element.addEventListener){ return element.addEventListener(eventType, handler, false); }else{ return element.attachEvent("on"+eventType, handler); } }, removeHandler : function (element, eventType, handler) { if(element.removeEventListener){ return element.removeEventListener(eventType, handler, false); }else{ return element.detachEvent("on" + eventType, handler); } }, getEvent: function (event) { return event || window.event; }, preventDefault: function (event) { if(event.preventDefault){ event.preventDefault(); }else{ event.returnValue = false; } }, bind : function (obj, handler) { return function () { return handler.apply(obj, arguments); } } }; window.onload = function () { var drag_div = document.getElementById("drag_div"); var drag = new Drag(drag_div, {handle: drag_div}); } </script> </html>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲免费的视频看| 亚洲国产欧美一区二区三区同亚洲| 97婷婷涩涩精品一区| 国模私拍视频一区| 国产精品美女久久久免费| 国产一区二区三区在线免费观看| 欧美激情喷水视频| 亚洲成人激情小说| 久久久精品2019中文字幕神马| 中文字幕亚洲字幕| 亚洲xxx视频| 欧美午夜视频在线观看| 国产精品香蕉国产| 国产成人精品视| 中文字幕亚洲二区| 久久精品一本久久99精品| 亚洲最大av在线| 亚洲一区中文字幕在线观看| 欧美午夜www高清视频| 中文字幕亚洲欧美在线| 国产精品极品美女在线观看免费| 最近2019中文字幕大全第二页| 在线播放国产一区中文字幕剧情欧美| 国模吧一区二区三区| 亚洲精品久久久一区二区三区| 欧美精品精品精品精品免费| 久久天天躁狠狠躁夜夜躁2014| 国产欧美日韩精品在线观看| 国产美女高潮久久白浆| 日韩视频免费中文字幕| 国产亚洲视频中文字幕视频| 亚洲成人精品视频| 欧美理论电影网| 影音先锋欧美在线资源| 久久99热精品这里久久精品| 成人深夜直播免费观看| 欧美激情国内偷拍| 久久久久久com| 中文字幕免费精品一区| 日本在线观看天堂男亚洲| 欧美二区乱c黑人| 亚洲专区在线视频| 亚洲色图综合久久| 亚洲伊人第一页| 一区二区三区动漫| 国产精品久久久久久久久久久新郎| 国产一区二区在线播放| 欧美精品在线极品| 在线精品视频视频中文字幕| 97超级碰碰人国产在线观看| 国产精品一区二区久久国产| 欧美丝袜一区二区| 亚洲天堂开心观看| 91丨九色丨国产在线| 国产精品福利在线观看网址| 久久久久久亚洲精品不卡| 欧美黑人xxxⅹ高潮交| 亚洲综合一区二区不卡| 成人黄色中文字幕| 国产一区深夜福利| 国产一区二区三区免费视频| 亚洲第一精品夜夜躁人人躁| 久久久999精品免费| 亚洲一区二区三区777| 色综合久久中文字幕综合网小说| 亚洲肉体裸体xxxx137| 国产主播在线一区| 国产精品免费一区二区三区都可以| 欧美成人一区二区三区电影| 国产狼人综合免费视频| 欧美国产日韩精品| 国产欧美日韩综合精品| 欧美精品videosex性欧美| 久久九九精品99国产精品| 国产精品久久久久久久久久三级| 青青草成人在线| 毛片精品免费在线观看| 亚洲自拍偷拍在线| 亚洲精品一区二区三区婷婷月| 亚洲最大的成人网| 日本一区二区在线免费播放| 欧美日韩国产999| 69av成年福利视频| 欧美精品一区二区三区国产精品| 色七七影院综合| 亚洲成人精品久久久| 成人国产亚洲精品a区天堂华泰| 中文字幕一精品亚洲无线一区| 国产成人精彩在线视频九色| 国产精品成人一区| 亚洲精品视频网上网址在线观看| 日韩在线播放av| 在线播放精品一区二区三区| 亚洲精品国产精品国自产在线| 伊是香蕉大人久久| 欧美精品久久久久久久久| 国产久一一精品| 欧美一级电影免费在线观看| 亚洲福利视频网站| 最近2019年中文视频免费在线观看| 欧美日韩国产在线| 久久人人97超碰精品888| 中文字幕视频在线免费欧美日韩综合在线看| 岛国视频午夜一区免费在线观看| 青青草原一区二区| 国产成人免费av电影| 成人欧美一区二区三区在线湿哒哒| 亚洲色在线视频| 91色中文字幕| 国产乱肥老妇国产一区二| 久久久黄色av| 成人国产精品久久久久久亚洲| 日韩av免费在线| 欧美日在线观看| 亚洲免费av网址| 亚洲精品自产拍| 欧美成人高清视频| 国产亚洲精品高潮| 国产美女久久精品| 国产91色在线|免| 亚洲成人网久久久| 国产日韩精品在线| 日韩精品免费在线视频观看| zzijzzij亚洲日本成熟少妇| 亚洲国产日韩欧美在线99| 国产在线精品成人一区二区三区| 美女视频黄免费的亚洲男人天堂| 欧美激情欧美狂野欧美精品| 91精品视频观看| 国产91在线高潮白浆在线观看| 成人观看高清在线观看免费| 欧美亚洲视频在线看网址| 国产欧美久久久久久| 成人性生交大片免费观看嘿嘿视频| 亚洲精品国产精品国自产在线| 欧美尺度大的性做爰视频| 日韩av在线网| 91精品国产自产在线老师啪| 欧美日本亚洲视频| 久久影视电视剧凤归四时歌| 日韩成人中文电影| 亚洲精品天天看| 色多多国产成人永久免费网站| 国产一区二区成人| 亚洲欧美在线x视频| 国产一区二区三区在线视频| 亚洲自拍小视频免费观看| 久久久精品一区| 91久久在线播放| 亚洲最新在线视频| 国产91精品久久久| 国产欧美亚洲精品| 欧美日韩性生活视频| 8x海外华人永久免费日韩内陆视频| 国产亚洲精品久久久久久777| 欧美激情小视频| 国产亚洲人成a一在线v站| 久久久爽爽爽美女图片| 久久99久国产精品黄毛片入口| 亚洲欧美日韩国产成人| 欧美电影在线免费观看网站| 亚洲成年人在线| 懂色aⅴ精品一区二区三区蜜月| 亚洲国产精彩中文乱码av在线播放|