这里用的是vuedraggable插件,传送门
在项目文件夹中下载使用
yarn add vuedraggable
npm i -S vuedraggable
<template>
<div>
<draggable group="people"
:list="myArray"
:disabled="!enabled"
class="list-group"
ghost-class="ghost"
:move="checkMove"
@start="drag=true" @end="drag=false">
<div class="list-group-item" v-for="element in myArray" :key="element.id" >{{element.name}}</div>
</draggable>
</div>
</template>
<script>
import draggable from 'vuedraggable'
export default {
components : { draggable},
data () {
return {
enabled: true,
myArray : []
}
},
methods: {
checkMove(){
console.log(this.myArray)//实时myarray数据,每拖动一次就会得到最新的排列数据
},
loadData () {
//请求后台 给this.myArray赋值
}
}
}
</script>
<style scoped>
.flip-list-move {
-webkit-transition: -webkit-transform 0.5s;
transition: -webkit-transform 0.5s;
transition: transform 0.5s;
transition: transform 0.5s, -webkit-transform 0.5s;
}
.no-move {
-webkit-transition: -webkit-transform 0s;
transition: -webkit-transform 0s;
transition: transform 0s;
transition: transform 0s, -webkit-transform 0s;
}
.ghost {
opacity: 0.5;
background: #c8ebfb;
}
.list-group {
min-height: 20px;
}
.list-group-item {
cursor: move;
}
.list-group-item i {
cursor: pointer;
}
.list-group-item:first-child {
border-top-left-radius: 4px;
border-top-right-radius: 4px;
}
.list-group-item {
position: relative;
display: block;
padding: 0px 15px;
margin-bottom: -1px;
background-color: #fff;
border: 1px solid #ddd;
}
.list-group-item:last-child {
margin-bottom: 0;
border-bottom-right-radius: 4px;
border-bottom-left-radius: 4px;
}
</style>