javascript拖曳互換div的位置實現(xiàn)示例
1 實現(xiàn)原理
利用dom元素的dragstart/ondragover/ondrop事件完成,在拖曳開始的時候獲取到拖曳元素,然后允許拖動,最后鼠標抬起后放到新的位置;這里用到了event.preventDefault()方法,很多人可能比較疑惑,這里簡單介紹一下
event.preventDefault() :該方法是讓瀏覽器不要執(zhí)行與事件關聯(lián)的默認動作
我們在dragover事件中使用,因為dragover關聯(lián)的默認動作是阻止將數(shù)據(jù)或者元素放置到其他元素中;所以需要通過event.preventDefault()禁止該默認事件,這樣就可以允許拖動元素到新的位置了
<!-- div拖曳調(diào)換順序 適用gis中切換圖層順序-->
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<style type="text/css">
body{
display: flex;
padding: 100px;
flex-direction: column;
}
div{
width: 100px;
height: 100px;
text-align: center;
}
</style>
</head>
<body>
<div style="background-color: red;width:200px;height:200px;" draggable="true">紅色</div>
<div style="background-color: green;width:100px" draggable="true">綠色</div>
<div style="background-color: blue;" draggable="true">藍色</div>
</body>
<script type="text/javascript">
let div =document.getElementsByTagName("div");
let container=null;
// 遍歷給每一個div綁定 dragstart dragover以及drop事件
for(let i=0;i<div.length;i++){
div[i].ondragstart=function(){
container=this
}
div[i].ondragover=function(){
event.preventDefault();
}
div[i].ondrop=function(){
debugger;
if(container!=null&&container!=this){
// 具體思路跟變量值互換一樣
let temp=document.createElement("div");
document.body.replaceChild(temp,this); //用新建的div占據(jù)目的位置
document.body.replaceChild(this,container);// 目的div放置在起始位置
document.body.replaceChild(container,temp) // 起始div放置在目的位置
debugger;
console.log('執(zhí)行業(yè)務邏輯')
}
}
}
</script>
</html>

到此這篇關于javascript拖曳互換div的位置實現(xiàn)示例的文章就介紹到這了,更多相關javascript拖曳互換div內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
詳解JavaScript中new操作符的解析和實現(xiàn)
javascirpt實現(xiàn)2個iframe之間傳值的方法
微信小程序?qū)崿F(xiàn)的數(shù)字滑塊拼圖效果

