亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2014年09月01日 09:10:23   投稿:whsnow  
首先改變被拖動元素的布局屬性,接著捕捉鼠標事件,當觸發(fā)mousedown時,記錄下當前鼠標在元素中的相對位置,接著處理mousemove事件

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

思路:

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

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

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

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

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

同時,應(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; // 鼠標在元素中的位置 
this._moveDrag = this.bind(this, this.moveDrag); 
this._stopDrag = this.bind(this, this.stopDrag); 

// 設(shè)置參數(shù) 
this.setOptions(options); 

// 設(shè)置鼠標去“拖”的“柄”對象(注意與被拖動的對象區(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 () {}, // 開始時回調(diào)函數(shù) 
onMove : function(){}, // 拖拽時回調(diào)函數(shù) 
onStop : function(){} // 停止時回調(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>

相關(guān)文章

  • Javascript實現(xiàn)Array和String互轉(zhuǎn)換的方法

    Javascript實現(xiàn)Array和String互轉(zhuǎn)換的方法

    這篇文章主要介紹了Javascript實現(xiàn)Array和String互轉(zhuǎn)換的方法,涉及JavaScript中toString方法與split方法的使用技巧,需要的朋友可以參考下
    2015-12-12
  • 小試SVG之新手小白入門教程

    小試SVG之新手小白入門教程

    這篇文章主要給大家介紹了關(guān)于SVG的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • 一個css與js結(jié)合的下拉菜單支持主流瀏覽器

    一個css與js結(jié)合的下拉菜單支持主流瀏覽器

    這是一個css和js結(jié)合的下拉菜單,經(jīng)測試支持主流瀏覽器,比較適合企業(yè)站,需要的朋友可以參考下
    2014-10-10
  • JavaScript實現(xiàn)統(tǒng)計文本框Textarea字數(shù)增強用戶體驗

    JavaScript實現(xiàn)統(tǒng)計文本框Textarea字數(shù)增強用戶體驗

    現(xiàn)在流行的Twitter等微博客網(wǎng)站,有一個很好的用戶體驗,就是在文本框中輸入文字的時候,會自動統(tǒng)計輸入的字符,并顯示用戶還能輸入的字符,在限制了140個字的微博客中,這樣的小提示可以很好的增強用戶體驗,本文也嘗試著實現(xiàn)一下
    2012-12-12
  • 引入JavaScript時alert彈出框顯示中文亂碼問題

    引入JavaScript時alert彈出框顯示中文亂碼問題

    今天在HTML中引入JavaScript文件運行時,alert彈出的提示框中文顯示為亂碼,怎么解決此問題呢?下面小編給大家?guī)砹艘隞avaScript時alert彈出框顯示中文亂碼問題的解決方法,一起看看吧
    2017-09-09
  • js模仿hover的具體實現(xiàn)代碼

    js模仿hover的具體實現(xiàn)代碼

    hover效果,想必大家并不陌生吧,接下來為大家介紹下使用js模仿hover,感興趣的朋友可以參考下
    2013-12-12
  • webpack搭建腳手架打包TypeScript代碼

    webpack搭建腳手架打包TypeScript代碼

    本文主要介紹了webpack搭建腳手架打包TypeScript代碼,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 每天一篇javascript學(xué)習(xí)小結(jié)(Array數(shù)組)

    每天一篇javascript學(xué)習(xí)小結(jié)(Array數(shù)組)

    這篇文章主要介紹了javascript中的Array數(shù)組知識點,對數(shù)組的基本使用方法,以及各種方法進行整理,感興趣的小伙伴們可以參考一下
    2015-11-11
  • 小程序掃描普通鏈接二維碼跳轉(zhuǎn)小程序指定界面方法

    小程序掃描普通鏈接二維碼跳轉(zhuǎn)小程序指定界面方法

    這篇文章主要介紹了小程序掃描普通鏈接二維碼跳轉(zhuǎn)小程序指定界面,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • JS引用傳遞與值傳遞的區(qū)別與用法分析

    JS引用傳遞與值傳遞的區(qū)別與用法分析

    這篇文章主要介紹了JS引用傳遞與值傳遞的區(qū)別與用法,結(jié)合實例形式較為詳細的對比分析了javascript引用傳遞與值傳遞的原理、區(qū)別、使用方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2018-06-06

最新評論