、el-table实现表格拖拽

时间:2025-01-19 16:03:23


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>