JavaScript實現(xiàn)拖拽功能
本文實例為大家分享了JavaScript實現(xiàn)拖拽功能的具體代碼,供大家參考,具體內(nèi)容如下
盒子拖拽—運用到的有onmousedown事件,onmousemove事件以及onmouseup事件
1、當鼠標點擊下去的時候我們需要獲取鼠標所在位置的橫縱坐標,然后獲取盒子的離頁面的橫縱方向的距離
2、計算出鼠標相對盒子的距離
3、當鼠標移動的時候,獲取鼠標移動的距離,在永鼠標此刻的位置減去鼠標相對盒子的距離,獲得的是盒子此刻的坐標位置
4、將這個位置賦值給盒子
5、鼠標抬起,清除鼠標移動事件;
代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>鼠標拖拽</title> <style> .box{ background-color: pink; width:200px; height:200px; border-radius: 50%; position: absolute; top:20px; left:100px; } </style> </head> <body> <div class="box"> </div> <script> window.onload = function(){ var box = document.getElementsByClassName('box')[0]; function drag (ele){ ele.onmousedown = function(e){ var e = e || window.event; //此處是為了兼容IE,因為IE中事件對象是作為全局對象( window.event )存在的; var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft; var pageY = e.pageY || e.clientY + document.documentElement.scrollTop; //獲取鼠標相對盒子的位置; var boxX = pageX - box.offsetLeft; var boxY = pageY - box.offsetTop; document.onmousemove = function(e){ var e = e || window.event; var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft; var pageY = e.pageY || e.clientY + document.documentElement.scrollTop; //將鼠標當前的坐標值減去鼠標相對盒子的位置,得到盒子當時的位置并將其賦值給盒子,實現(xiàn)移動效果 box.style.left = pageX - boxX +'px'; box.style.top = pageY - boxY + 'px'; } }; document.onmouseup = function () { //清除盒子的移動事件; document.onmousemove = null; }; } ; drag(box) } </script> </body> </html>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
總結(jié)分享10 個超棒的 JavaScript 簡寫技巧
這篇文章主要總結(jié)分享10 個超棒的 JavaScript 簡寫技巧,有合并數(shù)組、克隆數(shù)組、解構(gòu)賦值、模板字面量等技巧,需要的朋友可以參考一下2022-06-06javascript中使用replaceAll()函數(shù)實現(xiàn)字符替換的方法
第一次發(fā)現(xiàn)JavaScript中replace()?方法如果直接用str.replace("-","!")?只會替換第一個匹配的字符.2010-12-12