Vue+ElementUI技巧分享:结合Sortablejs实现表格行拖拽

文章目录

  • 前言
  • 准备工作
  • 示例代码
  • 代码说明
    • 1. 引入依赖和组件结构
    • 2. 组件数据和生命周期
    • 3. 实现拖拽功能
    • 4. 更新数据和服务器同步
  • 运行效果
  • 总结


前言

在很多动态网页应用中,用户界面的交互性是提高用户体验的关键。在 Vue.js 中,结合 Element UI 和 sortablejs,我们可以轻松实现表格的行拖拽功能。本文将演示如何在 Vue 项目中使用这些工具,并在拖拽后将数据更新到后端服务系统。


准备工作

确保你的项目中已经安装了 Element UI 和 sortablejs。如果还没有安装,可以通过以下命令进行安装:

npm install element-ui sortablejs

在你的主入口文件(如 main.jsapp.js)中引入 Element UI 和其样式:

import Vue from 'vue';
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';Vue.use(ElementUI);

示例代码

以下是一个包含表格行拖拽功能的 Vue 组件示例:

<template><div><el-table :data="planTableData"row-key="id"><el-table-column prop="createTime"label="日期"width="180"></el-table-column><el-table-column prop="event"label="事件"width="180"></el-table-column><!-- 其他列 --></el-table></div>
</template><script>
import Sortable from 'sortablejs'
import axios from 'axios' // 引入axios进行HTTP请求export default {name: 'PlanTableDraggable',data () {return {planTableData: []}},created () {this.planTableData = [{ id: 1, createTime: '2023-01-01', event: '事件1' },{ id: 2, createTime: '2023-01-02', event: '事件2' },{ id: 3, createTime: '2023-01-03', event: '事件3' }// ...更多测试数据]},mounted () {this.$nextTick(() => {const el = this.$el.querySelector('.el-table__body-wrapper tbody')Sortable.create(el, {onEnd: (event) => {const { oldIndex, newIndex } = eventthis.updateRowOrder(oldIndex, newIndex)}})})},methods: {updateRowOrder (oldIndex, newIndex) {const movedItem = this.planTableData.splice(oldIndex, 1)[0]this.planTableData.splice(newIndex, 0, movedItem)this.updateOrderOnServer()},updateOrderOnServer () {axios.post('/api/update-order', { newOrder: this.planTableData }).then(response => {console.log('Order updated:', response)}).catch(error => {console.error('Error updating order:', error)// 可能需要回滚操作})}}
}
</script>

这段代码演示了如何在 Vue 组件中结合 Element UI 的表格和 sortablejs 来实现行拖拽功能。主要步骤包括初始化表格数据、配置 sortablejs 来启用拖拽,并在拖拽结束时更新数据和同步到服务器。通过这种方式,您可以创建一个交互式且用户友好的表格界面。

代码说明

1. 引入依赖和组件结构

<template><div><el-table :data="planTableData" row-key="id"><!-- 表格列 --></el-table></div>
</template><script>
import Sortable from 'sortablejs'
import axios from 'axios'export default {// ...
}
</script>
  • <template> 部分定义了组件的 HTML 结构。这里使用了 Element UI 的 <el-table> 组件来创建表格。
  • :data="planTableData" 是一个动态属性(Vue 的 v-bind 简写),它绑定 planTableData 数组到表格的数据源。
  • row-key="id" 用于指定每行数据的唯一键值,这里假设每个数据项都有一个唯一的 id 字段。
  • import Sortable from 'sortablejs' 引入 sortablejs 库,它用于实现拖拽功能。
  • import axios from 'axios' 引入 axios 库,用于发送 HTTP 请求。

2. 组件数据和生命周期

export default {name: 'PlanTableDraggable',data () {return {planTableData: []}},created () {this.planTableData = [/* 初始数据 */]},mounted () {this.$nextTick(() => {const el = this.$el.querySelector('.el-table__body-wrapper tbody')Sortable.create(el, {/* 配置项 */})})},// ...
}
  • data() 函数返回组件的响应式数据,这里是 planTableData 数组,用于存储表格数据。
  • created() 生命周期钩子用于初始化 planTableData。这里可以替换为从服务器加载数据。
  • mounted() 钩子在组件被挂载到 DOM 后执行。这里使用 this.$nextTick 确保所有的子组件也被渲染。
  • mounted 内部,我们通过 this.$el.querySelector 获取表格的 DOM 元素,并使用 Sortable.create 初始化拖拽功能。

3. 实现拖拽功能

Sortable.create(el, {onEnd: (event) => {const { oldIndex, newIndex } = eventthis.updateRowOrder(oldIndex, newIndex)}
})
  • Sortable.create 接受两个参数:要应用拖拽的元素和配置对象。
  • onEnd 是一个事件处理器,当拖拽操作完成时触发。
  • event 参数提供了拖拽操作的详情,包括原始索引 oldIndex 和新索引 newIndex
  • this.updateRowOrder 是一个自定义方法,用于更新数组中元素的顺序。

4. 更新数据和服务器同步

methods: {updateRowOrder (oldIndex, newIndex) {const movedItem = this.planTableData.splice(oldIndex, 1)[0]this.planTableData.splice(newIndex, 0, movedItem)this.updateOrderOnServer()},updateOrderOnServer () {axios.post('/api/update-order', { newOrder: this.planTableData }).then(response => {console.log('Order updated:', response)}).catch(error => {console.error('Error updating order:', error)})}
}
  • updateRowOrder 通过数组的 splice 方法调整 planTableData 中元素的位置。
  • updateOrderOnServer 使用 axios 发送一个 POST 请求到服务器,以同步更新后的顺序。这里的 ‘/api/update-order’ 是示例 API 端点,需要根据实际后端服务进行调整。

运行效果

运行效果1
运行效果2


总结

通过结合 Vue.js、Element UI 和 sortablejs,我们可以有效地实现一个交云用户友好的拖拽表格界面,并确保数据的一致性通过与后端服务的交互维护。这不仅提高了应用程序的交互性,还增强了用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/203541.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

rust从0开始写项目-06-如何接受命令行参数clap-01

写web项目或者app等&#xff0c;必不可少的要接受参数和校验参数的准确性&#xff0c;基本也是项目开始的第一步&#xff0c;那么我们今天来看下rust提供了哪些优秀的crates 关注 vx golang技术实验室&#xff0c;获取更多golang、rust好文 Part1一、clap_v3 本来是想用structO…

【Flink on k8s】- 3 - Kubernetes 中的关键概念

目录 1、容器 VS 虚拟机 2、Kubernetes 架构 2.1 Master节点 2.2 Node 节点 3、Kubernetes 的基本对象

华为OD机试 - 分披萨(Java JS Python C)

题目描述 "吃货"和"馋嘴"两人到披萨店点了一份铁盘(圆形)披萨,并嘱咐店员将披萨按放射状切成大小相同的偶数个小块。但是粗心的服务员将披萨切成了每块大小都完全不同奇数块,且肉眼能分辨出大小。 由于两人都想吃到最多的披萨,他们商量了一个他们认…

初识树型结构与二叉树

1. 树型结构 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#xff08;它是根朝上&#xff0c;而叶朝下的&#xff09;&#xff0c;其物理结构如下图所示&#x…

Ubuntu 20.04 安装 mysql8 LTS

Ubuntu 20.04 安装 mysql8 LTS sudo apt-get update sudo apt-get install mysql-server mysql --version mysql Ver 8.0.35-0ubuntu0.20.04.1 for Linux on x86_64 ((Ubuntu)) Ubuntu20.04 是自带了 MySQL8. 几版本的&#xff0c;低于 20.04 则默认安装是 MySQL5.7.33 s…

rpm安装gitlab

1.rpm包下载 https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/ 2.进行安装 rpm -ivh gitlab-ce-15.9.7-ce.0.el7.x86_64.rpm --nodeps --force 3.配置访问地址 vim /etc/gitlab/gitlab.rb 4.重新加载配置以及重启服务 gitlab-ctl reconfiguregitlab-ctl resta…

<Linux>(极简关键、省时省力)《Linux操作系统原理分析之Linux文件管理(2)》(26)

《Linux操作系统原理分析之Linux文件管理&#xff08;2&#xff09;》&#xff08;26&#xff09; 8 Linux文件管理8.4 虚拟文件系统 VFS8.4.1 VFS 的工作原理8.4.2 VFS 超级块8.4.3VFS 的 inode 8.5 文件系统的安装与注册8.5.2 文件系统的注册 8 Linux文件管理 8.4 虚拟文件系…

HarmonyOS4.0从零开始的开发教程05 应用程序入口—UIAbility的使用

HarmonyOS&#xff08;三&#xff09;应用程序入口—UIAbility的使用 UIAbility概述 UIAbility是一种包含用户界面的应用组件&#xff0c;主要用于和用户进行交互。UIAbility也是系统调度的单元&#xff0c;为应用提供窗口在其中绘制界面。 每一个UIAbility实例&#xff0c;…

python数据分析基础

前言 2023年10月以来&#xff0c;一位在商学院就读的可爱同学遇上了一门课——python数据分析&#xff0c;并遇到了许多问题&#xff0c;找上了我&#xff0c;就此&#xff0c;我也开始了学习之路&#xff0c;虽然很浅显&#xff0c;但这些东西对部门同学来说也是受用的&#…

【XILINX】ISE chipscope出现错误 Can‘t load jre bin client jvm.dll

记录一个ISE软件使用过程中遇到的问题及解决方案。 问题 ISE chipscope出现错误 Cant load jre bin client jvm.dll C:\Xilinx\14.7\ISE_DS\ISE\bin\nt C:\Xilinx\14.7\ISE_DS\.xinstall\bin\nt C:\Xilinx\14.7\ISE_DS\.xinstall\bin\nt64 C:\Xilinx\14.7\ISE_DS\ISE\bin\nt6…

Weblogic CVE-2023-21839(metasploit版)

Step1&#xff1a;用docker搭建环境 Step2&#xff1a;docker查看映射端口 Step3&#xff1a;访问特定端口&#xff0c;然后靶标应用。 Step4&#xff1a;用metasploit进行攻击&#xff1a; 首先&#xff0c;打开metasploit&#xff0c;然后查询需要攻击的板块&#xff0…

【恶意刷券】电商中恶意刷券如何防止?

好的&#xff0c;更详细一些的解释如下&#xff1a; 1. **验证码验证** 验证码验证是防范恶意刷券的最基本手段之一。通过在关键操作前引入验证码&#xff0c;可以让机器无法进行自动化操作&#xff0c;只有真实用户才能完成验证。验证码种类包括文字、图片、计算等多种形式&…

C# 未处理System.InvalidOperationException HResult=-2146233079

1.异常信息&#xff1a; 未处理System.InvalidOperationException HResult-2146233079 MessageThe custom trace listener custom listener does not have a listener type name set or the type is invalid (F:\CBCT64\Output\Polaris.exe.Config line 45). SourceMicr…

[实践总结] 使用Apache HttpClient 4.x进行进行一次Http请求

使用Apache HttpClient 4.x进行进行一次Http请求 依赖 <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient --> <dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactI…

相位解包裹算法的研究现状和存在的问题

位相解包裹算法的研究现状 Phase unwrapping中文译法有&#xff1a;位相展开&#xff0c;位相解包寝&#xff0c;位相解缠绕等。因为数字全总术的重要步骤就是进行位相解包裹&#xff0c;所以伴随着数字全息显微术的发展&#xff0c;就对位相解包裹算法提出了更高的要求&#x…

华为OD机试 - 机场航班调度程序(Java JS Python C)

题目描述 XX市机场停放了多架飞机,每架飞机都有自己的航班号CA3385,CZ6678,SC6508等,航班号的前2个大写字母(或数字)代表航空公司的缩写,后面4个数字代表航班信息。 但是XX市机场只有一条起飞跑道,调度人员需要安排目前停留在机场的航班有序起飞。 为保障航班的有序…

Python:核心知识点整理大全4-笔记

目录 2.6 Python 之禅 2.7 小结 3.1 列表是什么 3.1.1 访问列表元素 3.1.2 索引从 0 而不是 1 开始 3.1.3 使用列表中的各个值 3.2 修改、添加和删除元素 3.2.1 修改列表元素 3.2.2 在列表中添加元素 2. 在列表中插入元素 1. 使用del语句删除元素 1 处的代码使用del…

指定分隔符对字符串进行分割 numpy.char.split()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 指定分隔符对字符串进行分割 numpy.char.split() 选择题 请问下列程序运行的的结果是&#xff1a; import numpy as np print("【执行】np.char.split(I.Love.China, sep .)") p…

【Flink on k8s】- 11 - 使用 Flink kubernetes operator 运行 Flink 作业

目录 1、创建本地镜像库 1.1 拉取私人仓库镜像 1.2 运行 1.3 本地浏览器访问 5000 端口

Linux进程解析(冯诺依曼体系结构,操作系统,进程初步解析)

冯诺依曼体系结构&#xff1a; 我们常见的计算机&#xff0c;如笔记本。我们常见的计算机&#xff0c;服务器&#xff0c;大部分都遵守冯诺依曼体系。 截至目前&#xff0c;我们所认识的计算机&#xff0c;都是有一个个的硬件组件组成&#xff1a; 中央处理器(CPU)&am…