sortablejs结合el-table

vuedraggable 不适合与 el-table 结合使用,所以选用 sortablejs 结合 el-table 实现拖拽表格行,几个关键的点:

  • 需要给 el-table 添加 row-key 属性,提供一个唯一的标识(否则会导致key复用,列表顺序与接口返回顺序不一致)
  • 获取到表格元素,使用 Sortable.create() 初始化后,可对其直接子元素进行拖拽
  • onEnd 事件获取拖拽后的数据,调用排序接口,再获取最新数据
xml 复制代码
<template>
  <div class="app-container">
    <!-- row-key -->
    <el-table class="el-drag-table" :data="tableData" row-key="id">
      <el-table-column prop="name" label="Name"></el-table-column>
      <el-table-column prop="age" label="age"></el-table-column>
      <el-table-column label="操作">
        <template #default>
          <i class="el-icon-rank drag-handle" style="cursor: grab"></i>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>
​
<script>
import Sortable from 'sortablejs'
import { deepClone } from '@/utils'
​
export default {
  name: 'SortableTable',
  data() {
    return {
      tableData: []
    }
  },
  created() {
    this.getList()
  },
  methods: {
    // 模拟接口请求
    getList() {
      const time = new Date().toLocaleTimeString()
      setTimeout(() => {
        Promise.resolve().then(() => {
          this.tableData = [
            { id: time, name: 'Matt', age: time },
            { id: time + 1, name: 'Matt', age: 2 },
            { id: time + 2, name: 'Matt', age: 3 }
          ]
​
          this.initDragTable()
        })
      }, 200)
    },
    initDragTable() {
      const tbody = document.querySelector('.el-table.el-drag-table .el-table__body-wrapper tbody')
​
      Sortable.create(tbody, {
        handle: '.drag-handle',
        animation: 150,
        onEnd: (evt) => {
          // 获取排序后的数据
          const { oldIndex, newIndex } = evt
          const copyData = deepClone(this.tableData)
          const movedRow = copyData[oldIndex]
          copyData.splice(oldIndex, 1)
          copyData.splice(newIndex, 0, movedRow)
          console.log(deepClone(copyData))
​
          // 调用排序接口...
​
          // 调用列表接口,获取最新数据
          this.getList()
        }
      })
    }
  }
}
</script>
​
<style scoped lang="scss"></style>

参考文档:

npm:www.npmjs.com/package/sor...

github:github.com/SortableJS/...

Demo:sortablejs.github.io/Sortable/

相关推荐
arvin_xiaoting15 分钟前
OpenClaw学习总结_II_频道系统_5:Signal集成详解
java·前端·学习·signal·ai agent·openclaw·signal-cli
哆啦A梦158821 分钟前
统一返回包装类 Result和异常处理
java·前端·后端·springboot
saadiya~25 分钟前
从插件冗余到极致流畅:我的 Vue 3 开发环境“瘦身”实录
前端·javascript·vue.js
Timer@1 小时前
LangChain 教程 03|快速开始:10 分钟创建第一个 Agent
前端·javascript·langchain
亿元程序员1 小时前
十年游戏程序员开箱实测:这台显示器,彻底改写了我的游戏开发日常
前端
凉城a1 小时前
前端性能优化解决方案
前端·性能优化
慧一居士1 小时前
Zod 功能、使用场景介绍以及对应场景使用示例
前端·vue.js
Timer@1 小时前
LangChain 教程 02|环境安装:从 0 到 1 搭建开发环境
javascript·人工智能·langchain·前端框架
我命由我123451 小时前
React - React 配置代理、搜索案例(Fetch + PubSub)、React 路由基本使用、NavLink
开发语言·前端·javascript·react.js·前端框架·html·ecmascript
The Sheep 20231 小时前
C# 操作XML
xml·前端·c#