原生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 相关文章推荐
用js判断是否为360浏览器的实现代码
Jan 15 Javascript
JS实现常见的TAB、弹出层效果(TAB标签,斑马线,遮罩层等)
Oct 08 Javascript
Bootstrap实现渐变顶部固定自适应导航栏
Aug 27 Javascript
jquery仿京东商品放大浏览页面
Jun 06 jQuery
Angular 5.0 来了! 有这些大变化
Nov 15 Javascript
vue中keep-alive的用法及问题描述
May 15 Javascript
基于Angularjs-router动态改变Title值的问题
Aug 30 Javascript
webpack开发环境和生产环境的深入理解
Nov 08 Javascript
微信小程序云开发之新手环境配置
May 16 Javascript
解决vue中使用proxy配置不同端口和ip接口问题
Aug 14 Javascript
js实现筛选功能
Nov 24 Javascript
低门槛开发iOS、Android、小程序应用的前端框架详解
Oct 16 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
把77A收信机改造成收音机
2021/03/02 无线电
ajax+php打造进度条代码[readyState各状态说明]
2010/04/12 PHP
PHPnow安装服务[apache_pn]失败的问题的解决方法
2010/09/10 PHP
PHP中“简单工厂模式”实例代码讲解
2012/09/04 PHP
添加到收藏夹代码(兼容几乎所有的浏览器)
2007/01/09 Javascript
常见JS效果之图片减速度滚动实现代码
2011/12/08 Javascript
表格单元格交错着色实现思路及代码
2013/04/01 Javascript
node.js适合游戏后台开发吗?
2014/09/03 Javascript
浅谈JavaScript事件的属性列表
2015/03/01 Javascript
兼容各大浏览器的JavaScript阻止事件冒泡代码
2015/07/09 Javascript
自动完成的搜索框javascript实现
2016/02/26 Javascript
AngularJS ng-controller 指令简单实例
2016/08/01 Javascript
JavaScript reduce和reduceRight详解
2016/10/24 Javascript
Vue请求JSON Server服务器数据的实现方法
2018/11/02 Javascript
浅谈python新手中常见的疑惑及解答
2016/06/14 Python
python 编码规范整理
2018/05/05 Python
Python中zip()函数的简单用法举例
2019/09/02 Python
Python函数中的可变长参数详解
2019/09/12 Python
Python pyautogui模块实现鼠标键盘自动化方法详解
2020/02/17 Python
Python3 io文本及原始流I/O工具用法详解
2020/03/23 Python
如何在django中实现分页功能
2020/04/22 Python
使用Pycharm(Python工具)新建项目及创建Python文件的教程
2020/04/26 Python
如何用H5实现一个触屏版的轮播器的实例
2017/01/09 HTML / CSS
HTML5中的拖放实现详解
2017/08/23 HTML / CSS
Probikekit日本:自行车套件,跑步和铁人三项装备
2017/04/03 全球购物
全球领先美式家具品牌:Ashley爱室丽家居
2017/08/07 全球购物
叙述DBMS对数据控制功能有哪些
2016/06/12 面试题
sort命令的作用和用法
2013/08/25 面试题
《玩具柜台前的孩子》教学反思
2014/02/13 职场文书
庆元旦迎新年广播稿
2014/02/18 职场文书
小学红领巾广播稿(3篇)
2014/09/13 职场文书
科级干部群众路线教育实践活动对照检查材料思想汇报
2014/09/20 职场文书
工作试用期自我评价
2015/03/10 职场文书
入党自传范文2015
2015/06/26 职场文书
Rust中的Struct使用示例详解
2022/08/14 Javascript
js 实现验证码输入框示例详解
2022/09/23 Javascript