如何实现js拖拽效果及原理解析
网络编程 2021-07-04 15:02www.168986.cn编程入门
这篇文章主要介绍了如何实现js拖拽效果及原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
元素拖拽分成3个步骤按下鼠标,移动鼠标,松开鼠标。
拖拽原理按下拖拽元素后开始监听文档中鼠标移动事件,然后再监听鼠标松开事件;鼠标移动时,元素div要随着鼠标一起移动,需要计算元素div位移的距离(移动的距离=鼠标离可视窗口的位置 – 鼠标在div中相对于左上角的位置)。然后松开鼠标时,删除移动事件和松开事件,元素完成拖拽。
一开始先监听鼠标按下事件mousedown,事件触发执行mouseHandler函数;
div.addEventListener("mousedown",mouseHandler);
进入mouseHandler函数后,进行if else if 的判断,如果是按下事件,就监听鼠标移动和松开事件,这里要用document文档来作为监听对象,如果使用元素div监听时,如果鼠标在移动过程超出了div元素,就无法拖拽元素;
进入移动事件,就把鼠标移动的距离(鼠标离可视窗口的位置 – 鼠标在div中相对于左上角的位置)赋值给元素的left和,元素就可以随着鼠标移动;
进入松开鼠标事件,删除了移动和送开鼠标事件,元素就会停在鼠标松开的位置
关键元素显示位置=鼠标离可视窗口的位置 – 鼠标相对于在div元素左上角的位置
js代码带注释
var div=document.querySelector("div"); var offsetX,offsetY; //定义全局变量用于接收鼠标坐标的变量 div.addEventListener("mousedown",mouseHandler); function mouseHandler(e){ //事件的执行函数自带参数e if(e.type==="mousedown"){ //e.type是执行事件的类型 offsetX=e.offsetX; offsetY=e.offsetY; document.addEventListener("mousemove",mouseHandler) document.addEventListener("mouseup",mouseHandler) //如果有鼠标移动或松开事件的发生执行mouseHandler函数 }else if(e.type==="mousemove"){ div.style.left=e.clientX-offsetX+"px"; //鼠标相对当前可视窗口的坐标 - 相对元素左上角的坐标 div.style.=e.clientY-offsetY+"px"; }else if(e.type==="mouseup"){ document.removeEventListener("mousemove",mouseHandler); document.removeEventListener("mouseup",mouseHandler); //删除鼠标移动和鼠标松开事件 } }
效果如图
注意div元素要设置定位才可以进行移动。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:JS数组的常用10种方法详解
下一篇:JS图片预加载三种实现方法解析
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南