JavaScript實(shí)現(xiàn)拖拽功能
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)拖拽功能的具體代碼,供大家參考,具體內(nèi)容如下
盒子拖拽—運(yùn)用到的有onmousedown事件,onmousemove事件以及onmouseup事件
1、當(dāng)鼠標(biāo)點(diǎn)擊下去的時候我們需要獲取鼠標(biāo)所在位置的橫縱坐標(biāo),然后獲取盒子的離頁面的橫縱方向的距離
2、計算出鼠標(biāo)相對盒子的距離
3、當(dāng)鼠標(biāo)移動的時候,獲取鼠標(biāo)移動的距離,在永鼠標(biāo)此刻的位置減去鼠標(biāo)相對盒子的距離,獲得的是盒子此刻的坐標(biāo)位置
4、將這個位置賦值給盒子
5、鼠標(biāo)抬起,清除鼠標(biāo)移動事件;
代碼:
<!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>鼠標(biāo)拖拽</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,因?yàn)镮E中事件對象是作為全局對象( window.event )存在的;
var pageX = e.pageX || e.clientX + document.documentElement.scrollLeft;
var pageY = e.pageY || e.clientY + document.documentElement.scrollTop;
//獲取鼠標(biāo)相對盒子的位置;
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;
//將鼠標(biāo)當(dāng)前的坐標(biāo)值減去鼠標(biāo)相對盒子的位置,得到盒子當(dāng)時的位置并將其賦值給盒子,實(shí)現(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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
總結(jié)分享10 個超棒的 JavaScript 簡寫技巧
這篇文章主要總結(jié)分享10 個超棒的 JavaScript 簡寫技巧,有合并數(shù)組、克隆數(shù)組、解構(gòu)賦值、模板字面量等技巧,需要的朋友可以參考一下2022-06-06
javascript實(shí)現(xiàn)貪吃蛇小游戲思路
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)貪吃蛇思路小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09
javascript中使用replaceAll()函數(shù)實(shí)現(xiàn)字符替換的方法
第一次發(fā)現(xiàn)JavaScript中replace()?方法如果直接用str.replace("-","!")?只會替換第一個匹配的字符.2010-12-12
微信小程序緩存支持二次開發(fā)封裝實(shí)現(xiàn)解析
這篇文章主要介紹了微信小程序緩存支持二次開發(fā)封裝實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12

