009:vue结合el-table实现表格行拖拽排序(基于sortablejs)

文章目录

  • [1. 实现效果](#1. 实现效果)
  • [2. 安装 `sortablejs` 插件](#2. 安装 sortablejs 插件)
  • [3. 完整组件代码](#3. 完整组件代码)
  • [4. 注意点](#4. 注意点)

1. 实现效果

2. 安装 sortablejs 插件

sortablejs 更多用法

shell 复制代码
cnpm i --save sortablejs

3. 完整组件代码

html 复制代码
<template>
  <div class="home">
    <div class="body">
      <el-table :data="tableData" border row-key="date" class="draggable-table" style="width: 100%">
        <el-table-column prop="sortNo" label="序号">
          <template slot-scope="{ row }">
            <img
              class="handle"
              :src="require('./icon-drop.png')"
              style="width: 20px; height: 20px; object-fit: contain"
            />
          </template>
        </el-table-column>
        <el-table-column prop="date" label="日期"></el-table-column>
        <el-table-column prop="name" label="姓名"></el-table-column>
        <el-table-column prop="address" label="地址"></el-table-column>
      </el-table>
    </div>
  </div>
</template>

<script>
  import Sortable from 'sortablejs'
  export default {
    name: 'Demo',
    data() {
      return {
        tableData: [
          // 略去数据,与前段代码一直
          { date: '2024-01-02', name: '张三1', address: '深圳市' },
          { date: '2024-01-03', name: '李四2', address: '成都市' },
          { date: '2024-01-04', name: '王五3', address: '重庆市' },
          { date: '2024-01-05', name: '麻六4', address: '上海市' },
          { date: '2024-01-07', name: 'kk5', address: '上海市01' },
          { date: '2024-01-08', name: 'fantay6', address: '上海市02' },
        ],
      }
    },
    mounted() {
      const tbody = document.querySelector('.draggable-table .el-table__body-wrapper tbody')
      new Sortable(tbody, {
        handle: '.handle', // handle's class
        animation: 150,
        // 需要在odEnd方法中处理原始eltable数据,使原始数据与显示数据保持顺序一致
        onEnd: ({ newIndex, oldIndex }) => {
          const targetRow = this.tableData[oldIndex]
          this.tableData.splice(oldIndex, 1)
          this.tableData.splice(newIndex, 0, targetRow)
          console.table(this.tableData)
        },
      })
    },
  }
</script>

<style scoped lang="scss">
  .home {
    .body {
      width: 890px;
      height: 500px;
      border: #ff3366 solid 10px;
      box-sizing: border-box;
      padding: 20px;
      box-sizing: border-box;
    }
  }
  .handle {
    cursor: move;
    display: flex;
    align-content: center;
  }
</style>

4. 注意点

  1. 很多文章使用 Sortable.create 但是我这样用没生效,使用 new Sortable 就行了
  2. 页面table添加类 draggable-table
  3. handle 可以配置可拖拽的指定元素,默认是当前行触发
相关推荐
iRuriCatt3 小时前
智慧景区管理系统 | 计算机毕设项目
java·前端·spring boot·vue·毕设
吹牛不交税4 小时前
admin.net框架使用记录
vue·.netcore
是梦终空9 小时前
计算机毕业设计263—基于Springboot+Vue的影视推荐和评分系统(源代码+数据库)
spring boot·vue·毕业设计·课程设计·协同过滤算法·影评系统·影视推荐系统
EstherNi11 小时前
小程序中,下拉多选的组件,有写死的三级下拉,样式需要修改
javascript·小程序·vue
青春男大1 天前
已有后端基础学习前端简单页面交互
前端·javascript·学习·typescript·vue
shejizuopin1 天前
基于Spring Boot的高校科研管理系统的设计与实现(毕业论文)
java·spring boot·vue·毕业设计·论文·毕业论文·高校科研管理系统的设计与实现
皮卡穆1 天前
Vue3 + Swiper.js 实现无缝轮播图组件
前端·javascript·vue
泰勒疯狂展开2 天前
Vue3研学-组件的生命周期
开发语言·前端·vue
千寻技术帮2 天前
10392_基于SpringBoot的大学迎新系统
mysql·vue·源码·springboot·代码·新生报到
总爱写点小BUG3 天前
VU-Icons:打造极致体验的 Vue3 & UniApp 双端 SVG 图标库
uni-app·vue·组件库·图标组件库