原生javascript实现拖动元素示例代码


Posted in Javascript onSeptember 01, 2014

本文介绍原生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>
Javascript 相关文章推荐
在网页中屏蔽快捷键
Sep 06 Javascript
javascript放大镜效果的简单实现
Dec 09 Javascript
禁止页面刷新让F5快捷键及右键都无效
Jan 22 Javascript
ExtJS中设置下拉列表框不可编辑的方法
May 07 Javascript
浅析js预加载/延迟加载
Sep 25 Javascript
JavaScript中获取高度和宽度函数总结
Oct 08 Javascript
js,jq,css多方面实现简易下拉菜单功能
May 13 Javascript
提高Node.js性能的应用技巧分享
Aug 10 Javascript
vue2.0开发入门笔记之.vue文件的生成和使用
Sep 19 Javascript
jQuery插件实现的日历功能示例【附源码下载】
Sep 07 jQuery
vue的注意规范之v-if 与 v-for 一起使用教程
Aug 04 Javascript
Vue export import 导入导出的多种方式与区别介绍
Feb 12 Javascript
使用text方法获取Html元素文本信息示例
Sep 01 #Javascript
textarea不能通过maxlength属性来限制字数的解决方法
Sep 01 #Javascript
超级好用的jQuery圆角插件 Corner速成
Aug 31 #Javascript
Html5的placeholder属性(IE兼容)实现代码
Aug 30 #Javascript
通过js为元素添加多项样式,浏览器全兼容写法
Aug 30 #Javascript
原生js仿jq判断当前浏览器是否为ie,精确到ie6~8
Aug 30 #Javascript
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
Aug 30 #Javascript
You might like
PHP安全配置
2006/10/09 PHP
simplehtmldom Doc api帮助文档
2012/03/26 PHP
PHP生成二维码与识别二维码的方法详解【附源码下载】
2019/03/07 PHP
php+ajax实现文件切割上传功能示例
2020/03/03 PHP
PHP使用Http Post请求发送Json对象数据代码解析
2020/07/16 PHP
URI、URL和URN之间的区别与联系
2006/12/20 Javascript
javascript 表单规则集合对象
2009/07/21 Javascript
Jquery知识点一 Jquery的ready和Dom的onload的区别
2011/01/15 Javascript
6款经典实用的jQuery小插件及源码(对话框/提示工具等等)
2013/02/04 Javascript
JSP跨iframe如何传递参数实现代码
2013/09/21 Javascript
jquery鼠标停止移动事件
2013/12/21 Javascript
轻松创建nodejs服务器(10):处理上传图片
2014/12/18 NodeJs
jQuery多媒体插件jQuery Media Plugin使用详解
2014/12/19 Javascript
js随机生成字母数字组合的字符串 随机动画数字
2015/09/02 Javascript
详解Bootstrap glyphicons字体图标
2016/01/04 Javascript
微信小程序 滚动到某个位置添加class效果实现代码
2017/04/19 Javascript
关于使用js算总价的问题
2017/06/23 Javascript
详解tween.js的使用教程
2017/09/14 Javascript
vue router 用户登陆功能的实例代码
2019/04/24 Javascript
判断“命令按钮”是否被鼠标单击详解
2019/07/31 Javascript
layui select 禁止点击的实现方法
2019/09/05 Javascript
微信小程序wxml列表渲染原理解析
2019/11/27 Javascript
python中文乱码的解决方法
2013/11/04 Python
浅谈Python中range和xrange的区别
2017/12/20 Python
Python基于百度AI的文字识别的示例
2018/04/21 Python
Python进阶之全面解读高级特性之切片
2019/02/19 Python
Python 把序列转换为元组的函数tuple方法
2019/06/27 Python
Python 私有属性和私有方法应用场景分析
2020/06/19 Python
在数据文件自动增长时,自动增长是否会阻塞对文件的更新
2014/05/01 面试题
大学生毕业自我评价范文分享
2013/11/11 职场文书
经典婚礼主持词
2014/03/13 职场文书
文明倡议书范文
2014/04/15 职场文书
致地震灾区的慰问信
2015/03/23 职场文书
工作表现证明
2015/06/15 职场文书
Python实现简单的猜单词
2021/06/15 Python
Win11 Build 21996.1 Dev版怎么样? win11系统截图欣赏
2021/11/21 数码科技