GitHub地址链接:/SortableJS/
中文网址:/vue-draggable/
注意:el-table 一定要指定 row-key!!!不然拖拽会出现问题。
install
yarn add vuedraggable
npm i -S vuedraggable
引入
import Sortable from "sortablejs";
<el-table class="draggable-table" :data="tableData" row-key="id" ></el-table>
// 表格行拖拽
rowDrag() {
const el = (".draggable-table .el-table__body-wrapper > table > tbody")[0];
const vm = this;
(el, {
disabled: false, // 拖拽是否可用
ghostClass: 'sortable-ghost', //拖拽样式
animation: 150, // 拖拽延时
onEnd: function (e) { // 拖拽结束时触发
let arr = ;
(, 0, (, 1)[0]); // 数据处理,获取最新的表格数据
vm.$nextTick(function () {
= arr;
})
},
});
},
如果不想使用Element-ui,可以到中文文档去看看例子。
中文网址:/vue-draggable/
中文文档的例子如下:
<template>
<div style="padding:10px">
<!--使用draggable组件-->
<div>点击第一列数字进行拖动,其他列拖拽无效</div>
<table class="itxst">
<draggable v-model="list" animation="500" force-fallback="true" handle=".move" @start="onStart" @end="onEnd" :move="checkMove">
<tr v-for="item in list" :key="" >
<td style="width:50px" class="move">{{}}</td>
<td style="width:250px">{{}}</td>
</tr>
</draggable>
</table>
</div>
</template>
<style scoped>
/*定义要拖拽元素的样式*/
{
color:#333333;
border: #ddd solid 1px;
border-collapse: collapse;
}
th {
border: #ddd solid 1px;
padding: 8px;
background-color: #dedede;
}
td {
border: #ddd solid 1px;
padding: 8px;
background-color: #ffffff;
}
tr {
cursor: pointer;
}
:hover {
cursor: move;
}
</style>
<script>
//导入draggable组件
import draggable from 'vuedraggable'
export default {
//注册draggable组件
components: {
draggable,
},
data() {
return {
drag:false,
//定义要被拖拽对象的数组
list:[
{id:1,name:''},
{id:2,name:''},
{id:3,name:''},
]
};
},
methods: {
checkMove(evt) {
(evt)
return true;
},
//开始拖拽事件
onStart(){
=true;
},
//拖拽结束事件
onEnd() {
=false;
},
},
};
</script>