js如何实现简单的拖拽效果
发表于:2025-11-11 作者:千家信息网编辑
千家信息网最后更新 2025年11月11日,这篇文章主要为大家展示了"js如何实现简单的拖拽效果",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"js如何实现简单的拖拽效果"这篇文章吧。1.拖拽的基本效
千家信息网最后更新 2025年11月11日js如何实现简单的拖拽效果
这篇文章主要为大家展示了"js如何实现简单的拖拽效果",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"js如何实现简单的拖拽效果"这篇文章吧。
1.拖拽的基本效果
思路:
鼠标在盒子上按下时,准备移动 (事件加给物体)
鼠标移动时,盒子跟随鼠标移动 (事件添加给页面)
鼠标抬起时,盒子停止移动 (事件加给页面)
var o = document.querySelector('div'); //鼠标按下 o.onmousedown = function (e) { //鼠标相对于盒子的位置 var offsetX = e.clientX - o.offsetLeft; var offsetY = e.clientY - o.offsetTop; //鼠标移动 _document.onmousemove = function (e) { o.style.left = e.clientX - offsetX + "px"; o.style.top = e.clientY - offsetY + "px"; } //鼠标抬起 _document.onmouseup = function () { _document.onmousemove = null; _document.onmouseup = null; } }2.拖拽的问题
若盒子中出现了文字,或盒子自身为图片,由于浏览器的默认行为(文字和图片本身就可以拖拽),我们可以设置return false来阻止它的默认行为,但这种拦截默认行为在IE低版本中,不适用,可以使用全局捕获来解决IE的问题。
全局捕获
全局捕获仅适用于IE低版本浏览器。
一旦为指定节点添加全局捕获,则页面中其它元素就不会触发同类型事件。
3.完整版的拖拽
var o = document.querySelector('div'); //鼠标按下 o.onmousedown = function (e) { if (o.setCapture) { //IE低版本 o.setCapture() } e = e || window.event //鼠标相对于盒子的位置 var offsetX = e.clientX - o.offsetLeft; var offsetY = e.clientY - o.offsetTop; //鼠标移动 _document.onmousemove = function (e) { e = e || window.event o.style.left = e.clientX - offsetX + "px"; o.style.top = e.clientY - offsetY + "px"; } //鼠标抬起 _document.onmouseup = function () { _document.onmousemove = null; _document.onmouseup = null; if (o.releaseCapture) { o.releaseCapture();//释放全局捕获 } } return false;//标准浏览器的默认行为 }以上是"js如何实现简单的拖拽效果"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
鼠标
全局
盒子
移动
效果
事件
行为
内容
浏览器
版本
篇文章
页面
浏览
位置
图片
文字
问题
学习
帮助
元素
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
视图 数据库安全
怎么将数据库的插入语句导出
软件开发工作岗位需求量
空间网络安全与量子密钥
数据库表建不了外键
k8s 数据库集群
2009年国际网络安全会议
公司接受软件开发的会计处理
星月网络技术有限公司
航海王之热血航线登录服务器问题
网络安全工程师经验
网络安全座谈会要建立什么
阴阳师服务器没有了
关于网络安全的传播学理论
校园网网络技术与设备选型
采集服务器信息
济南管理软件开发哪家做的好
工业机器人软件开发培训
宝鸡软件开发定制
大象精灵软件开发老板李昌勤图片
3路服务器
审计局网络安全自查情况表
软件开发模块基本功能
网络安全和信息化中级职称
java软件开发招聘信息
西华大学网络安全试题
中心管理服务器套什么定额
世界十大工业软件开发公司
怎样加强网络安全工作的建议
知网数据库外观专利图片