vue拖拽div位置互换
html<div class="item" v-for="(item, index) in divList" :key="index" draggable="true"@dragstart="handleDragStart($event, item)"@dragenter="handleDragEnter($event, item)"@dragover.prevent=...
·
html
<div class="item" v-for="(item, index) in divList" :key="index" draggable="true"
@dragstart="handleDragStart($event, item)"
@dragenter="handleDragEnter($event, item)"
@dragover.prevent="handleDragover($event, item)"
@drop="handleDrop($event, item)"
@dragend="handleDragEnd($event, item)">
{{item.name}}
</div>
js
data () {
return {
divList: [
{ key: 1, name: 'one'},
{ key: 2, name: 'two'},
{ key: 3, name: 'three'}
],
dragging: null
}
},
methods: {
// 当元素被拖动时
handleDragStart(e, item) {
this.dragging = item
},
// 当被鼠标拖动的对象进入其容器范围内时触发此事件
handleDragEnter(e) {
// 为需要移动的元素设置dragstart事件
e.dataTransfer.effectAllowed = 'move'
},
// 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
handleDragover(e) {
// 首先把div变成可以放置的元素,即重写dragenter/dragover
// 在dragenter中针对放置目标来设置!
e.dataTransfer.dropEffect = 'move'
},
// 当放置被拖元素时
handleDrop(e, item) {
e.dataTransfer.dropEffect = 'move'
if(item === this.dragging){
return
}
const newItems = [...this.divList]
const from = newItems.indexOf(this.dragging)
const to = newItems.indexOf(item)
newItems[from] = item
newItems[to] = this.dragging
this.divList = newItems
},
// 完成元素拖动后触发
handleDragEnd() {
this.dragging = null
}
}
css
<style>
.item {
display: inline-block;
margin-left: 20px;
margin-bottom: 20px;
width: 200px;
height: 200px;
border-radius: 4px;
box-shadow: 0 2px 4px rgba(0, 0, 0, .12), 0 0 6px rgba(0, 0, 0, .04);
}
</style>
更多推荐
已为社区贡献5条内容
所有评论(0)