本文實例為大家分享了JavaScript實現滑鼠拖曳效果的具體程式碼,供大家參考,具體內容如下
這次的效果圖如下:

我認為這個實驗的困難是保持盒子和滑鼠的相對位置不變,透過滑鼠按下和移動來實現拖曳的效果
如何實現拖曳的效果呢?
我們需要用到三個函數: onmousedown 、 onmousemove 、 onmouseup ,分別表示滑鼠按下、滑鼠移動、滑鼠抬起
在滑鼠按下的回呼函數中,我們需要透過clientX和clientY取得滑鼠的初始位置,透過offsetLeft和offsetTop取得盒子的初始位置,然後計算滑鼠初始位置和盒子初始位置的差值;
在滑鼠移動的回調函數中,我們需要根據滑鼠的位置和之前計算得到的差值來取得盒子現在的位置,然後改變其left和top值,不要忘記將position設為absolute(因為我就忘記了。。。)
在滑鼠抬起的回調函數中,我們需要清除滑鼠移動和滑鼠抬起,透過將onmousemove和onmouseup值設為null即可
還要注意! ! !
滑鼠移動函數和抬起函數都要寫在滑鼠按下函數中,因為我們是要在滑鼠按下這個動作之後來設計之後的行為,而且很重要的一點是:
滑鼠按下函數是p的,滑鼠移動和滑鼠抬起是document的
因為我們的意思並不是滑鼠在p中移動,而是在整個頁面移動
重點大概是這些了,下面是代碼:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
#box{
width: 100px;
height: 100px;
background-color: aquamarine;
border-radius: 14px;
box-shadow: 2px 2px 6px rgba(0,0,0,.3);
/* 好傢伙都沒設定定位就想移動改變left。 。 。 */
position: absolute;
}
</style>
</head>
<body>
<div id="box"></div>
<script>
let box=document.getElementById("box");
box.onmousedown=function(event){
let disx=event.clientX-box.offsetLeft;
let disy=event.clientY-box.offsetTop;
//此處不是box.onmousemove,是document.onmousemove
document.onmousemove=function(event){
box.style.left=event.clientX-disx+'px';
box.style.top=event.clientY-disy+'px';
}
//要寫在ommousedown裡面document.onmouseup=function(){
//這倆都要置為null
document.onmousemove=null;
document.onmouseup=null;
return false;
}
}
</script>
</body>
</html>相關推薦:【JavaScript影片教學】
以上就是js實作類比滑鼠拖曳事件(附圖文實例)的詳細內容,更多請關注php中文網其它相關文章!