jquery简单的拖动效果实现原理及示例 - Web前端
作者:98wpeu发布时间:2026-06-02分类:网页前端技术浏览:5
导读:复制代码代码如下:<!DOCtypehtml><HTML><metahttp-eqUIv="Content-Type"content="tex...
复制代码 代码如下:
<!DOCtypehtml>
<HTML>
<metahttp-eqUIv="Content-Type" content="text/html; charset=utf-8" />
<title>简单拖曵原理实例</title>
<style type="text/CSS">
#drag{width:400px;height:300px;background:url(HTTP://upload.yxgz.cn/uploadfile/2009/0513/20090513052611873.jpg);cursor:move;position:absolute;top:100px;left:100px;border:solid 1px #ccc;}
h2{color:#fff;background: none repeat scroll 0 0 rgba(16, 90, 31, 0.7);color:#FFFFFF;height:40px;line-height:40px;margin:0;}
</style>
<script src="http://Ajax.googleAPIs.com/ajax/libs/JQuery/1.7.2/jQuery.min.JS" type="text/javascript"></script>
<script type="text/JavaScript">
$(function(){
/*--------------拖曳效果----------------
*原理:标记拖曳状态dragging ,坐标位置iX, iY
* mousedown:fn(){dragging = true, 记录起始坐标位置,设置鼠标捕获}
* mouSEOver:fn(){判断如果dragging = true, 则当前坐标位置 - 记录起始坐标位置,绝对定位的元素获得差值}
* mouseup:fn(){dragging = false, 释放鼠标捕获,防止冒泡}
*/
var dragging = false;
var iX, iY;
$("#drag").mousedown(function(e) {
dragging = true;
iX = e.clientX - this.offsetLeft;
iY = e.clientY - this.offsetTop;
this.setCapture && this.setCapture();
return false;
});
document.onmouSEMove = function(e) {
if (dragging) {
var e = e || window.event;
var oX = e.clIEntX - iX;
var oY = e.clientY - iY;
$("#drag").css({"left":oX + "px", "top":oY + "px"});
return false;
}
};
$(document).mouseup(function(e) {
dragging = false;
$("#drag")[0].releaseCapture();
e.cancelBubble = true;
})
})
</script>
</head>
<body>
<div id="drag">
<h2>来拖动我啊</h2>
</div>
</body>
</html>
<!DOCtypehtml>
<HTML>
<metahttp-eqUIv="Content-Type" content="text/html; charset=utf-8" />
<title>简单拖曵原理实例</title>
<style type="text/CSS">
#drag{width:400px;height:300px;background:url(HTTP://upload.yxgz.cn/uploadfile/2009/0513/20090513052611873.jpg);cursor:move;position:absolute;top:100px;left:100px;border:solid 1px #ccc;}
h2{color:#fff;background: none repeat scroll 0 0 rgba(16, 90, 31, 0.7);color:#FFFFFF;height:40px;line-height:40px;margin:0;}
</style>
<script src="http://Ajax.googleAPIs.com/ajax/libs/JQuery/1.7.2/jQuery.min.JS" type="text/javascript"></script>
<script type="text/JavaScript">
$(function(){
/*--------------拖曳效果----------------
*原理:标记拖曳状态dragging ,坐标位置iX, iY
* mousedown:fn(){dragging = true, 记录起始坐标位置,设置鼠标捕获}
* mouSEOver:fn(){判断如果dragging = true, 则当前坐标位置 - 记录起始坐标位置,绝对定位的元素获得差值}
* mouseup:fn(){dragging = false, 释放鼠标捕获,防止冒泡}
*/
var dragging = false;
var iX, iY;
$("#drag").mousedown(function(e) {
dragging = true;
iX = e.clientX - this.offsetLeft;
iY = e.clientY - this.offsetTop;
this.setCapture && this.setCapture();
return false;
});
document.onmouSEMove = function(e) {
if (dragging) {
var e = e || window.event;
var oX = e.clIEntX - iX;
var oY = e.clientY - iY;
$("#drag").css({"left":oX + "px", "top":oY + "px"});
return false;
}
};
$(document).mouseup(function(e) {
dragging = false;
$("#drag")[0].releaseCapture();
e.cancelBubble = true;
})
})
</script>
</head>
<body>
<div id="drag">
<h2>来拖动我啊</h2>
</div>
</body>
</html>
相关推荐
- jquery弹出框的用法示例(一) - Web前端
- jQuery快速上手:写jQuery与直接写JS的区别详细解析 - Web前端
- jquery对象和DOM对象的区别介绍 - Web前端
- Jquery右下角抖动、浮动 实例代码(兼容ie6、FF) - Web前端
- Jquery绑定事件(bind和live的区别介绍) - Web前端
- Jquery时间验证和转换工具小例子 - Web前端
- 放弃用你的InnerHTML来输出HTML吧 jQuery Tmpl不详细讲解 - Web前端
- 网站如何做到完全不需要jQuery也可以满足简单需求 - Web前端
- 使用PHP+JQuery+Ajax分页的实现 - Web前端
- 防止jQuery ajax Load使用缓存的方法小结 - Web前端
- 网页前端技术排行
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


