蝙蝠岛资源网 Design By www.hbtsch.com
本文介绍原生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" "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>
标签:
原生js,拖动元素
蝙蝠岛资源网 Design By www.hbtsch.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
蝙蝠岛资源网 Design By www.hbtsch.com
暂无原生javascript实现拖动元素示例代码的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年11月08日
2025年11月08日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]