国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

原生javascript實(shí)現(xiàn)拖動元素示例代碼

2019-11-20 14:13:27
字體:
供稿:網(wǎng)友

本文介紹原生javascript實(shí)現(xiàn)元素拖動。

思路:

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

2.捕捉鼠標(biāo)事件"mousedown","mousemove","mouseup";

3.當(dāng)觸發(fā)"mousedown"時(shí),記錄下當(dāng)前鼠標(biāo)在元素中的相對位置,_x,_y;

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

5.當(dāng)觸發(fā)"mouseup"時(shí)間時(shí),終止拖動。

同時(shí),應(yīng)考慮代碼的封裝性和瀏覽器的兼容性,代碼如下:

<!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; // 鼠標(biāo)在元素中的位置 this._moveDrag = this.bind(this, this.moveDrag); this._stopDrag = this.bind(this, this.stopDrag); // 設(shè)置參數(shù) this.setOptions(options); // 設(shè)置鼠標(biāo)去“拖”的“柄”對象(注意與被拖動的對象區(qū)別) this.handle = this.$(this.options.handle); // 設(shè)置回調(diào)函數(shù) 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 () {}, // 開始時(shí)回調(diào)函數(shù) onMove : function(){}, // 拖拽時(shí)回調(diào)函數(shù) onStop : function(){} // 停止時(shí)回調(diào)函數(shù) }; 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>
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 侯马市| 二连浩特市| 龙陵县| 天气| 岐山县| 长治市| 南和县| 儋州市| 诸城市| 广宁县| 娱乐| 阳信县| 陇西县| 沁源县| 镇沅| 祥云县| 中方县| 襄垣县| 衡山县| 大关县| 岱山县| 峨眉山市| 呼伦贝尔市| 榆社县| 韶山市| 探索| 鄢陵县| 莒南县| 日照市| 精河县| 盘山县| 原平市| 鄂温| 威信县| 衡阳县| 莫力| 土默特左旗| 凤翔县| 澄城县| 平利县| 弥渡县|