原生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 相关文章推荐
splice slice区别
Oct 09 Javascript
jquery $.each() 使用小探
Aug 23 Javascript
jQuery:delegate中select()不起作用的解决方法(实例讲解)
Jan 26 Javascript
随鼠标移动的时钟非常漂亮遗憾的是只支持IE
Aug 12 Javascript
jQuery中[attribute!=value]选择器用法实例
Dec 31 Javascript
Javascript中的几种URL编码方法比较
Jan 23 Javascript
js实现仿爱微网两级导航菜单效果代码
Aug 31 Javascript
JS实现搜索框文字可删除功能
Dec 28 Javascript
详解用webpack2搭建angular2的项目
Jun 22 Javascript
MUI实现上拉加载和下拉刷新效果
Jun 30 Javascript
解决angular2在双向数据绑定时[(ngModel)]无法使用的问题
Sep 13 Javascript
Vue.js 中 axios 跨域访问错误问题及解决方法
Nov 21 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运算符的知识大全
2011/11/03 PHP
php+ajax实现带进度条的上传图片功能【附demo源码下载】
2016/09/14 PHP
yii插入数据库防并发的简单代码
2017/05/27 PHP
PhpStorm的使用教程(本地运行PHP+远程开发+快捷键)
2020/03/26 PHP
PHP实现简单日历类编写
2020/08/28 PHP
JS 树形递归实例代码
2010/05/18 Javascript
javascript中使用new与不使用实例化对象的区别
2015/06/22 Javascript
javascript设计模式之对象工厂函数与构造函数详解
2015/07/30 Javascript
深入解析JavaScript中函数的Currying柯里化
2016/03/19 Javascript
Node.js DES加密的简单实现
2016/07/07 Javascript
js 性能优化之算法和流程控制
2017/02/15 Javascript
BootStrap 表单控件之单选按钮水平排列
2017/05/23 Javascript
Node.js如何对SQLite的async/await封装详解
2019/02/14 Javascript
微信小程序自定义组件components(代码详解)
2019/10/21 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
Python 返回汉字的汉语拼音
2009/02/27 Python
Python中is与==判断的区别
2017/03/28 Python
python3判断url链接是否为404的方法
2018/08/10 Python
Django2.1.3 中间件使用详解
2018/11/26 Python
python之cv2与图像的载入、显示和保存实例
2018/12/05 Python
解决keras使用cov1D函数的输入问题
2020/06/29 Python
python中Mako库实例用法
2020/12/31 Python
Python 中如何使用 virtualenv 管理虚拟环境
2021/01/21 Python
python爬虫爬取某网站视频的示例代码
2021/02/20 Python
CSS3解决移动页面上点击链接触发色块的问题
2016/06/03 HTML / CSS
x-ua-compatible content=”IE=7, IE=9″意思理解
2013/07/22 HTML / CSS
荷兰鞋子在线:Nelson Schoenen
2017/12/25 全球购物
Hunkemöller瑞士网上商店:欧洲最大的内衣品牌之一
2018/12/03 全球购物
外企求职信范文分享
2013/12/31 职场文书
我未来的职业规划范文
2014/01/11 职场文书
2014社区健康教育工作总结
2014/12/16 职场文书
为自己工作观后感
2015/06/11 职场文书
新手必备之MySQL msi版本下载安装图文详细教程
2021/05/21 MySQL
变长双向rnn的正确使用姿势教学
2021/05/31 Python
python之np.argmax()及对axis=0或者1的理解
2021/06/02 Python
Python机器学习之决策树和随机森林
2021/07/15 Javascript