html5 拖放互换位置 怎样获取交换位置的两个div的ID

<!DOCTYPEhtml><html><head><metacharset="utf-8"/><title></title><styletype="text/css">... <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<style type="text/css">
/*.column {float: left;}*/
.column div{width: 178px;height: 56px;margin-bottom: 2px;}
.box1{background-color: black;}
.box2{background-color: bisque;}
.box3{background-color: gray;}
.box4{background-color: wheat;}
</style>
</head>
<body>
<div class="column" draggable="true">
<div class="box1">

</div>
</div>
<div class="column" draggable="true">
<div class="box2">

</div>
</div>
<div class="column" draggable="true">
<div class="box3">

</div>
</div>
<div class="column" draggable="true">
<div class="box4">

</div>
</div>

<script>

function handleDragStart(e) {

this.style.opacity = '1';

dragSrcEl = this;

e.dataTransfer.effectAllowed = 'move';

e.dataTransfer.setData('text/html', this.innerHTML);

}

function handleDragEnter(e) {

this.classList.add('over');

}

function handleDragLeave(e) {

this.classList.remove('over');

}

function handleDragOver(e) {

if (e.preventDefault) {

e.preventDefault();

}

return false;

}

function handleDrop(e) {

if (dragSrcEl != this) {

dragSrcEl.innerHTML = this.innerHTML;

this.innerHTML = e.dataTransfer.getData('text/html');

}

return false;

}

function handleDragEnd(e) {

this.style.opacity = '1';

[].forEach.call(divs, function(d) {

d.classList.remove('over');

});

}

var divs = document.querySelectorAll('.column');

[].forEach.call(divs, function(d) {

d.addEventListener('dragstart', handleDragStart, false);

d.addEventListener('dragenter', handleDragEnter, false);

d.addEventListener('dragover', handleDragOver, false);

d.addEventListener('dragleave', handleDragLeave, false);

d.addEventListener('drop', handleDrop, false);

d.addEventListener('dragend', handleDragEnd, false);

});

</script>
</body>
</html>
展开
 我来答
GYvu3w8
2016-05-23 · TA获得超过431个赞
知道小有建树答主
回答量:346
采纳率:0%
帮助的人:237万
展开全部
<BODY>
<div id=SS>
</div>
<input id=I1>
<input id=I2>
<button onclick='change()'/>change</button>
</BODY>
<SCRIPT>
var kk=[
'<div id="content1"style="width:500px; height:20px; border:1px solid black">B1</div>',
'<div id="content2"style="width:500px; height:20px; border:1px solid black">B2</div> ',
'<div id="content3"style="width:500px; height:20px; border:1px solid black">B3</div> ',
'<div id="content4"style="width:500px; height:20px; border:1px solid black">B4</div>'
]
var cx=[0,1,2,3];
for(var i = 0 ;i<kk.length;i++){
SS.insertAdjacentHTML('beforeEnd',kk[i])
}
function change(){
var c0;
var c1;
for(var i =0 ; i<cx.length;i++){
if ( SS.children(i).innerHTML== I1.value ){
c0=i
}
if( SS.children(i).innerHTML== I2.value ){
c1=i
}
}
var a=cx[c1]
cx[c1]=cx[c0]
cx[c0]=a
for(var i =0 ; i<cx.length;i++){
SS.removeChild(SS.children(0))
SS.insertAdjacentHTML("beforeEnd",kk[cx[i]]);
}
}
</SCRIPT>
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
你的心有道墙l
2016-05-23 · TA获得超过842个赞
知道小有建树答主
回答量:691
采纳率:100%
帮助的人:267万
展开全部
获取被拖两个的id再用js动态更改
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式