Table表格组件不请求接口,实现表格里某条数据的本地编辑功能(Vue3+ArcoDesign)

本文主要是介绍Table表格组件不请求接口,实现表格里某条数据的本地编辑功能(Vue3+ArcoDesign),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【背景】
在 Vue3 + ArcoDesign项目中,使用ArcoDesign-Table表格组件不请求接口,实现表格里某条数据的本地编辑功能。最后统一通过接口发送数据。

【步骤】

1. 在表格每条数据列后添加一个“编辑”按钮,点击该按钮弹出一个对话框,用于修改表格行的数据。

示例页面如下:
在这里插入图片描述

template主要示例代码如下(父组件):

// <template>
<a-table :data="tableData" ><template #rules="{ record }"><a-buttontype="text"size="small"@click="handleEdit(record.list)">编辑</a-button></template>
</a-table>// 子组件
<edit-fault// editFaultVisible.value控制子组件的显隐v-model:visible="editFaultVisible"// propsTableData.value用于往子组件内传递数据:props-table-data="propsTableData"// handle-ok用于接收子组件emit过来的数据@handle-ok="editHandleOk"
></edit-fault>

script主要示例代码如下(父组件):

// <script setup lang="ts">
// 打开子组件弹框
const handleEdit = (data: array) => {propsTableData.value = data;editFaultVisible.value = true;
};

2. 在对话框中添加一个表单,用于输入修改后的数据,将修改后的数据更新到表格中,同时关闭对话框。

示例页面如下:

在这里插入图片描述
弹框主要示例代码如下(子组件):

<a-modalv-model:visible="dialogVisible"title="编辑"width="auto":mask-closable="false"unmount-on-close@ok="handleOk"@cancel="handleCancel"
><a-table:data="renderData"></a-table>
</a-modal>
// 接收父组件传来的值
const props = defineProps<{visible: boolean;propsTableData: any;
}>();
// 将接收到的值赋值,在弹框展示
renderData.value = props.propsTableData;
// 注册emits事件
const emits = defineEmits(['update:visible','handleOk']);
// 弹框内点击确定
const handleOk = () => {// 编辑结束后在弹框内点击确定按钮,将编辑后的数据renderData.value传给父组件emits('handleOk', renderData.value);// 关闭子组件的弹框dialogVisible.value = false;
};

3. 父组件拿到子组件通过emits传过来的值

示例代码如下:

// 接收子组件弹框编辑后传过来的数据
const editHandleOk = (list: any) => {// 在父组件table绑定的tableData值里通过indexOf找到子组件内编辑的这条数据首次出现的位置。const dataIndex = tableData.value.indexOf(list);// 将list替换数组tableDataCopy中索引为dataIndex的元素。它删除了原来的元素,然后将新值插入到该位置const tableDataCopy = [...tableData.value];tableDataCopy.splice(dataIndex, 1, ...list);// 重新给父组件赋值tableData.value = tableDataCopy;
};

4. 在父组件内点击保存时,将编辑后的数据统一发送接口进行更新

示例代码如下:

const submit = async () => {await editData(tableData.value)
}

这篇关于Table表格组件不请求接口,实现表格里某条数据的本地编辑功能(Vue3+ArcoDesign)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023652

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程