javascript拖曳互換div的位置實(shí)現(xiàn)示例
1 實(shí)現(xiàn)原理
利用dom元素的dragstart/ondragover/ondrop事件完成,在拖曳開始的時候獲取到拖曳元素,然后允許拖動,最后鼠標(biāo)抬起后放到新的位置;這里用到了event.preventDefault()方法,很多人可能比較疑惑,這里簡單介紹一下
event.preventDefault() :該方法是讓瀏覽器不要執(zhí)行與事件關(guān)聯(lián)的默認(rèn)動作
我們在dragover事件中使用,因為dragover關(guān)聯(lián)的默認(rèn)動作是阻止將數(shù)據(jù)或者元素放置到其他元素中;所以需要通過event.preventDefault()禁止該默認(rèn)事件,這樣就可以允許拖動元素到新的位置了
<!-- 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">藍(lán)色</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è)務(wù)邏輯')
}
}
}
</script>
</html>

到此這篇關(guān)于javascript拖曳互換div的位置實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)javascript拖曳互換div內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js 執(zhí)行上下文和作用域的相關(guān)總結(jié)
這篇文章主要介紹了js 執(zhí)行上下文和作用域的相關(guān)知識總結(jié),幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2021-02-02
詳解JavaScript中new操作符的解析和實(shí)現(xiàn)
javascirpt實(shí)現(xiàn)2個iframe之間傳值的方法
微信小程序?qū)崿F(xiàn)的數(shù)字滑塊拼圖效果
JS中video標(biāo)簽自動播放音視頻并繪制波形圖效果

