js拖拽效果的原理及實現
拖拽功能主要是用在讓用戶做一些自定義的動作,比如拖動排序,彈出框拖動移動等等
拖拽的流程動作
1、鼠標按下 會觸發onmousedown事件
2、鼠標移動 會觸發onmousemove事件
3、鼠標松開 會觸發onmouseup事件
拖拽原理
1.鼠標按下+鼠標移動 = 拖拽——-事件 onmousedown + onmousemove
2.鼠標松開 = 無拖拽——–停止拖拽 onmouseup
3.鼠標偏移 = 拖拽距離
當點擊dom的時候,記錄當前鼠標的坐標值,也就是x、y值,以及被拖拽的dom的top、left值,而且還要在鼠標按下的回調函數裡添加鼠標移動的事件:
document.addEventListener(“mousemove”, moving, false)
和添加鼠標抬起的事件
document.addEventListener(“mouseup”,function() { document.removeEventListener(“mousemove”, moving, false); }, false);
這個抬起的事件是為瞭解除鼠標移動的監聽,因為隻有在鼠標按下才可以拖拽,抬起就停止不會移動瞭。
當鼠標按下鼠標移動的時候,記錄移動中的x、y值,那麼這個被拖拽的dom的top和left值就是:
top=鼠標按下時記錄的dom的top值+(移動中的y值 – 鼠標按下時的y值)
left=鼠標按下時記錄的dom的left值+(移動中的x值 – 鼠標按下時的x值);
//極簡單版 var div=document.querySelector("div"); // 按下時開始監聽在文檔中鼠標移動的事件 // 開始監聽鼠標松開鍵的事件 // 隻有按下時才準備拖拽 div.onmousedown=function(e1){ // 當鼠標在文檔移動時,不能再div上移動,因為鼠標可能離開div,造成無法拖拽 div.onmousemove=function(e){ // 當鼠標移動時,將當前鼠標相對視口的坐標賦值給元素的left和top // 因為我們需要在按下的位置拖拽,因此我們還需要獲取按下鍵鼠標相對div的左上角位置 // 使用當前鼠標位置減去這個相對元素的左上角位置,保證鼠標所按位置拖拽 div.style.left=e.clientX-e1.offsetX+"px"; div.style.top=e.clientY-e1.offsetY+"px"; } // 當釋放鼠標鍵時,刪除鼠標移動事件和刪除鼠標釋放事件 div.onmouseup=function(){ document.onmousemove=null; document.onmouseup=null; } } //簡單版 var div=document.querySelector("div"); var offsetX,offsetY; div.addEventListener("mousedown",mouseDownHandler); function mouseDownHandler(e){ offsetX=e.offsetX offsetY=e.offsetY document.addEventListener("mousemove",mousemoveHandler) document.addEventListener("mouseup",mouseupHandler) } function mousemoveHandler(e){ div.style.left=e.clientX-offsetX+"px" div.style.top=e.clientY-offsetY+"px" } function mouseupHandler(e){ document.removeEventListener("mousemove",mousemoveHandler) document.removeEventListener("mouseup",mouseupHandler) } // 簡單升級版 var div=document.querySelector("div"); var offsetX,offsetY; div.addEventListener("mousedown",mouseHandler); function mouseHandler(e){ if(e.type==="mousedown"){ offsetX=e.offsetX; offsetY=e.offsetY; document.addEventListener("mousemove",mouseHandler) document.addEventListener("mouseup",mouseHandler) }else if(e.type==="mousemove"){ div.style.left=e.clientX-offsetX+"px" div.style.top=e.clientY-offsetY+"px" }else if(e.type==="mouseup"){ document.removeEventListener("mousemove",mouseHandler) document.removeEventListener("mouseup",mouseHandler) } }
註
a、被拖拽的元素的樣式要設置成絕對或相對位置才有效果。
b、拖拽加到document,不然內容會脫離
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。