原生javascript實(shí)現(xiàn)拖動(dòng)元素示例代碼
本文介紹原生javascript實(shí)現(xiàn)元素拖動(dòng)。
思路:
1.首先改變被拖動(dòng)元素的布局屬性,關(guān)鍵是“position:absolue”;
2.捕捉鼠標(biāo)事件"mousedown","mousemove","mouseup";
3.當(dāng)觸發(fā)"mousedown"時(shí),記錄下當(dāng)前鼠標(biāo)在元素中的相對(duì)位置,_x,_y;
4.緊接著處理"mousemove"事件,通過改變?cè)氐膖op和left屬性來移動(dòng)元素;
5.當(dāng)觸發(fā)"mouseup"時(shí)間時(shí),終止拖動(dòng)。
同時(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); // 被拖動(dòng)的對(duì)象
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)去“拖”的“柄”對(duì)象(注意與被拖動(dòng)的對(duì)象區(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();
// 注冊(cè)開始拖動(dòng)事件
this.addHandler(this.handle, "mousedown", this.bind(this, this.startDrag));
},
// 改變被拖動(dòng)對(duì)象的布局屬性
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, //事件對(duì)象
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>
- javascript實(shí)現(xiàn)可拖動(dòng)變色并關(guān)閉層窗口實(shí)例
- JavaScript實(shí)現(xiàn)DIV層拖動(dòng)及動(dòng)態(tài)增加新層的方法
- 最精簡的JavaScript實(shí)現(xiàn)鼠標(biāo)拖動(dòng)效果的方法
- javascript實(shí)現(xiàn)鼠標(biāo)拖動(dòng)改變層大小的方法
- JavaScript模塊隨意拖動(dòng)示例代碼
- JavaScript 實(shí)現(xiàn)鼠標(biāo)拖動(dòng)元素實(shí)例代碼
- Javascript簡單實(shí)現(xiàn)可拖動(dòng)的div
- JavaScript:Div層拖動(dòng)效果實(shí)例代碼
- javascript實(shí)現(xiàn)行拖動(dòng)的方法
相關(guān)文章
Javascript實(shí)現(xiàn)Array和String互轉(zhuǎn)換的方法
這篇文章主要介紹了Javascript實(shí)現(xiàn)Array和String互轉(zhuǎn)換的方法,涉及JavaScript中toString方法與split方法的使用技巧,需要的朋友可以參考下2015-12-12
一個(gè)css與js結(jié)合的下拉菜單支持主流瀏覽器
這是一個(gè)css和js結(jié)合的下拉菜單,經(jīng)測試支持主流瀏覽器,比較適合企業(yè)站,需要的朋友可以參考下2014-10-10
JavaScript實(shí)現(xiàn)統(tǒng)計(jì)文本框Textarea字?jǐn)?shù)增強(qiáng)用戶體驗(yàn)
現(xiàn)在流行的Twitter等微博客網(wǎng)站,有一個(gè)很好的用戶體驗(yàn),就是在文本框中輸入文字的時(shí)候,會(huì)自動(dòng)統(tǒng)計(jì)輸入的字符,并顯示用戶還能輸入的字符,在限制了140個(gè)字的微博客中,這樣的小提示可以很好的增強(qiáng)用戶體驗(yàn),本文也嘗試著實(shí)現(xiàn)一下2012-12-12
引入JavaScript時(shí)alert彈出框顯示中文亂碼問題
今天在HTML中引入JavaScript文件運(yùn)行時(shí),alert彈出的提示框中文顯示為亂碼,怎么解決此問題呢?下面小編給大家?guī)砹艘隞avaScript時(shí)alert彈出框顯示中文亂碼問題的解決方法,一起看看吧2017-09-09
每天一篇javascript學(xué)習(xí)小結(jié)(Array數(shù)組)
這篇文章主要介紹了javascript中的Array數(shù)組知識(shí)點(diǎn),對(duì)數(shù)組的基本使用方法,以及各種方法進(jìn)行整理,感興趣的小伙伴們可以參考一下2015-11-11
小程序掃描普通鏈接二維碼跳轉(zhuǎn)小程序指定界面方法
這篇文章主要介紹了小程序掃描普通鏈接二維碼跳轉(zhuǎn)小程序指定界面,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

