基于sortablejs实现拖拽element-ui el-table表格行进行排序

简介: 基于sortablejs实现拖拽element-ui el-table表格行进行排序

可以用原生的dragstart、drag、dragend、dragover、drop、dragleave实现这个效果,但是有现成的轮子就不要重复造了,看效果:

<template>
  <el-table :class="$options.name" :data="tableData" ref="table" row-key="ID">
    <!-- 注意:必须要定义row-key="ID",否者会导致拖拽顺序错乱 -->
    <el-table-column type="index" label="序号" width="60" />
    <el-table-column prop="label" label="列名">
      <template slot-scope="scope">
        <el-link :type="scope.row.type" :underline="false">{{ scope.row.label }}</el-link>
      </template>
    </el-table-column>
  </el-table>
</template>
<script>
import sortablejs from "sortablejs"; //npm install sortablejs --save
export default {
  name: "dragTableRow",
  data() {
    return {
      tableData: [
        { ID: 1, value: 1, label: "显示文本1", type: `primary` },
        { ID: 2, value: 2, label: "显示文本2", type: `success` },
        { ID: 3, value: 3, label: "显示文本3", type: `warning` },
        { ID: 4, value: 4, label: "显示文本4", type: `danger` },
        { ID: 5, value: 5, label: "显示文本5", type: `info` },
      ],
    };
  },
  mounted() {
    this.initDragSortTableRow(); //拖拽表格行排序
  },
  methods: {
    initDragSortTableRow() {
      let el = this.$refs.table.$el.querySelectorAll(
        ".el-table__body-wrapper > table > tbody"
      )[0];
      sortablejs.create(el, {
        ghostClass: "ghostClass", //定义拖拽的时候接触到的行样式
        setData: (dataTransfer) => {
          dataTransfer.setData("自定义传参字段", "传输内容");
        },
        onEnd: (e) => {
          this.$g.array.moveArrayElement(this.tableData, e.oldIndex, e.newIndex); //修改数组的顺序
          console.log(e.originalEvent.dataTransfer.getData("自定义传参字段"));
        },
      });
    },
  },
};
</script>
 
<style lang="scss" scoped>
.dragTableRow {
  >>> .ghostClass {
    background-color: #ecf5ff;
    td {
      border-bottom-color: #409eff;
    }
  }
}
</style>


相关文章
|
9月前
|
JavaScript
element-ui table表格多选后再打开默认选中
element-ui table表格多选后再打开默认选中
|
10月前
|
前端开发 JavaScript UED
element-ui 表格数据究竟隐藏着怎样的神秘样式与格式化技巧?快来揭开谜底!
【8月更文挑战第22天】《element-ui 表格数据样式及格式化案例》展示了如何利用 element-ui 的表格组件实现美观且易读的数据展示。通过简单配置,可以自定义表格样式,如边框、背景色等,并通过 formatter 实现数据格式化,例如将成绩保留一位小数。此外,还能依据条件设置行样式,如成绩达优则高亮显示,从而增强用户体验和数据可读性。
174 1
|
10月前
|
计算机视觉
ElementUI——vue2+element-ui 2.x的动态表格和表单
ElementUI——vue2+element-ui 2.x的动态表格和表单
272 1
|
10月前
|
JavaScript 开发者
Element UI & Element Plus之改变表格单元格颜色
这篇文章展示了如何在Element UI和Element Plus框架中使用`:cell-style`属性来根据条件改变表格单元格的颜色。
935 0
Element UI & Element Plus之改变表格单元格颜色
|
10月前
|
JavaScript 前端开发 Shell
Element-ui Table表格导出功能的实现
Element-ui Table表格导出功能的实现
249 0
|
11月前
Element UI 表格【列宽自适应】
Element UI 表格【列宽自适应】
224 0
|
11月前
Element UI 【表格合计】el-table 实战范例 -- 添加单位,自定义计算逻辑
Element UI 【表格合计】el-table 实战范例 -- 添加单位,自定义计算逻辑
670 0
|
23天前
|
开发框架 前端开发 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
69 15
|
23天前
|
编解码 前端开发 Java
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
65 11
|
23天前
|
存储 开发框架 API
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发二
本文详细介绍了基于声明式UI开发的健康饮食应用的设计与实现过程。内容涵盖从基础环境搭建到复杂功能实现的全流程,包括创建简单视图、构建布局(如Stack、Flex)、数据模型设计、列表与网格布局构建,以及页面跳转和数据传递等核心功能。 本文通过实际案例深入浅出地解析了声明式UI开发的关键技术和最佳实践,为开发者提供了宝贵的参考。
59 14

热门文章

最新文章