Ant Design Vue Table组件全单元格编辑实现方案

在ant上的table常见用法是一行的元素可编辑,如下:

在这里插入图片描述
但是现在有一个需求是全部单元格均可编辑,如何实现呢?

  • 表格组件
<a-tablev-if="query.personnel_type === '0'"size="middle"row-key="id":scroll="{ x: 'max-content' }":columns="columns":data-source="data":loading="loading":pagination="false"
/>
  • 表头数据
{title: '月份',width: 170,dataIndex: 'created_at',
},
{title: '基础员工(个)',width: 120,dataIndex: 'basic',
},
{title: '高技能员工(个)',width: 120,dataIndex: 'senior',
},
{title: '专业专家(个)',width: 120,dataIndex: 'expert',
},
{title: '实习生(个)',width: 120,dataIndex: 'trainee',
},
  • 效果

在这里插入图片描述

  • 使用<Input>插槽可以Table组件内部渲染样式

在这里插入图片描述
在Table的Api第一行就显示的是具名插槽,使用这个插槽可以对表格内部数据个人化操作。

text, record, index, column分别表示单元格的文本数据,一行的数据,索引和列的表头元素。一般情况下通过v-if判断表头元素对该列做个性化。

  • 具名插槽编辑
    <a-tablev-if="query.personnel_type === '0'"size="middle"row-key="id":scroll="{ x: 'max-content' }":columns="columns":data-source="data":loading="loading":pagination="false"><template#bodyCell="{ record, column }"><templatev-if="column.dataIndex === 'senior'"><a-input:placeholder="record[column.dataIndex]"@change="(e) => handleChange(e.target.value, record, column)"/></template></template></a-table>

关键代码

 <template#bodyCell="{ record, column }"><templatev-if="column.dataIndex === 'senior'"><a-input:placeholder="record[column.dataIndex]"@change="(e) => handleChange(e.target.value, record, column)"/></template></template>

v-if="column.dataIndex === 'senior'"判断表头是senior元素将其变成一个input输入框,效果如下:

在这里插入图片描述

  • 实现全单元格编辑

对所需要全局编辑的表头做判断即可,如下:

<template#bodyCell="{ record, column }"
><templatev-if="['basic', 'senior', 'expert', 'trainee'].includes(column.dataIndex)"><a-input:placeholder="record[column.dataIndex]"@change="(e) => handleChange(e.target.value, record, column)"/></template>
</template>

在这里插入图片描述

改造后就得到了除时间外全部单元格都可编辑的一个Table,但是在默认情况下并不比想要其展现可编辑状态,而是在点击某个按钮后显示可编辑状态。

  • 编辑状态改变

基于该方式我们可以在输入框添加一个v-if判断

 <a-inputv-if="isShowGlobalEdit":placeholder="record[column.dataIndex]"@change="(e) => handleChange(e.target.value, record, column)"/>

在默认情况下就是忽略了input插槽。

在这里插入图片描述

设置按钮绑定响应事件

 // 全单元格编辑isShowAllEdit() {this.isShowGlobalEdit = true},cloneAllEdit() {this.isShowGlobalEdit = false},

这里情况下肯会不成功,应为表格已经渲染了,这时候再去改变if的状态已经无效了。这里有两种实现方法,第一种就是vue的钩子函数,把isShowGlobalEdit beforeUpdate()重新赋值一下使表格重新渲染就可以了。另一种如下:

import { cloneDeep } from 'lodash/lang'// 全单元格编辑isShowAllEdit() {this.isShowGlobalEdit = cloneDeep(this.isShowGlobalEdit === true)},cloneAllEdit() {this.isShowGlobalEdit = cloneDeep(this.isShowGlobalEdit === false)},

使用这种深度监听也可以实现,这个可以自行去查资料哈。

  • 数据监听

到这里全单元格的编辑已经做出来了,但是如何获取数据呢?

在这里插入图片描述
在输入数据时,当鼠标移开数据就消失了,这是由于在vue中数据使响应式的,这里的输入并未改变实际的状态。在Table中提供了changeAPI帮助获取变化,如下:

在这里插入图片描述

<template#bodyCell="{ record, column }"
><templatev-if="['basic', 'senior', 'expert', 'trainee'].includes(column.dataIndex)"><a-inputv-if="isShowGlobalEdit":placeholder="record[column.dataIndex]"@change="(e) => handleTableChange(e)"/></template>
</template>
    handleTableChange(e) {console.log(e)},

在这里插入图片描述
可以看到每次输入都会触发事件,控制台打印一个对象,这个对象肯定式包含输入值的,找出它即可,如下:

在这里插入图片描述

再次改造函数如下:

<template#bodyCell="{ record, column }"
><templatev-if="['basic', 'senior', 'expert', 'trainee'].includes(column.dataIndex)"><a-inputv-if="isShowGlobalEdit":placeholder="record[column.dataIndex]"@change="(e) => handleTableChange(e.target.value, record, column)"/></template>
</template>

e.target.value, record, column这三个参数都是需要的。record, column用于判断是那行的数据修改了,不然全局修改不知道是修改了哪些数据。

在这里插入图片描述

到此修改的数据就可以被实时获取了,接下来是组装数据,全局修改需要知道修改是那行的数据。

  • 组装数据

在这里插入图片描述

一行的数据也传递到函数,如下:

在这里插入图片描述

由这些数据可以知道是那一行和那一列的数据,就可以组装了。

handleTableChange(e, record, column) {record[column.dataIndex] = ethis.dataDuplication.push(record)
},

在这里插入图片描述
这样组装发信每次输入都会触发,导出数组重复数据,这里需要判断,由于id是唯一的,可以根据id判断。如下:

handleTableChange(e, record, column) {// 过滤重复idthis.dataDuplication = this.dataDuplication.filter((item) => item.id !== record.id)record[column.dataIndex] = ethis.dataDuplication.push(record)
},

在这里插入图片描述

最终获取的数据是更改后具有id的数据,这样的数据传递到后端可以直接更具id修改。到此全部单元格修改已经完成了。

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

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

相关文章

web前端分离:解析其深层含义与影响

web前端分离&#xff1a;解析其深层含义与影响 在现今的web开发领域&#xff0c;前端分离已经成为一个不可忽视的趋势。那么&#xff0c;web前端分离究竟意味着什么呢&#xff1f;本文将从四个方面、五个方面、六个方面和七个方面&#xff0c;深入剖析其内涵&#xff0c;并探讨…

【CS.OS】操作系统如何使用分页和分段技术管理内存

1000.5.CS.OS.1.3-基础-内存管理-操作系统如何使用分页和分段技术管理内存-Created: 2024-06-09.Sunday10:24 操作系统的内存管理是一个复杂而关键的功能&#xff0c;它确保了程序可以高效、安全地运行。虚拟内存管理是其中一个重要的概念&#xff0c;它通过分页和分段技术来实…

Leetcode刷题笔记8

162. 寻找峰值 162. 寻找峰值 - 力扣&#xff08;LeetCode&#xff09; 对于所有有效的 i 都有 nums[i] ! nums[i 1] 解法一&#xff1a;暴力解法 从第一个位置一直向后走&#xff0c;然后分情况即可1. 第二个元素就往下降&#xff0c;那么第一个元素就是峰顶 2. 一直遍历…

温度传感器十大品牌

温度传感器品牌排行榜-十大热电偶品牌-热敏电阻品牌排行-Maigoo品牌榜

【Vue】获取模块内的mutations方法

目标&#xff1a; 掌握模块中 mutation 的调用语法 注意&#xff1a; 默认模块中的 mutation 和 actions 会被挂载到全局&#xff0c;需要开启命名空间&#xff0c;才会挂载到子模块。 调用方式&#xff1a; 直接通过 store 调用 $store.commit(模块名/mutations名 , 额外…

k8s面试题大全,保姆级的攻略哦(三)

目录 1、简述ETCD及其特点? 2、简述ETCD适应的场景? 3、简述什么是Kubernetes? 4、简述Kubernetes和Docker的关系? 5、简述Kubernetes中什么是Minikube、Kubectl、Kubelet? 6、简述Kubernetes常见的部署方式? 7、简述Kubernetes如何实现集群管理? 8、简述Kubern…

卷积 - 感受野(Receptive Field)

卷积 - 感受野&#xff08;Receptive Field&#xff09; flyfish 感受野&#xff08;Receptive Field&#xff09;是指卷积神经网络中某一层的一个特定神经元能够“看到”并响应的输入图像区域。简单来说&#xff0c;它是指卷积核在输入图像上滑动过程中每次覆盖的区域。感受…

09-Eureka-搭建eureka服务

09-Eureka-搭建eureka服务 1.动手实践&#xff1a; 1.搭建EurekaServer 2.将user-service、order-service都注册到Eureka 3.在order-service中完成服务拉取&#xff0c;然后通过负载均衡挑选一个服务&#xff0c;实现远程调用 2.搭建EurekaServer服务步骤如下&#xff1a; 1.…

【设计模式】结构型设计模式之 组合模式

介绍 这里的组合模式&#xff0c;与之前的设计模式中的"组合关系"完全是两码事&#xff0c;这里的组合模式主要用来处理结构为树形的数据。 组合模式&#xff08;Composite Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许你将对象组合成树状结构来表示…

MongoDB ObjectId 详解

MongoDB ObjectId 详解 MongoDB 是一个流行的 NoSQL 数据库,它使用 ObjectId 作为文档的唯一标识符。ObjectId 是一个 12 字节的 BSON 类型,它在 MongoDB 中用于保证每个文档的唯一性。本文将详细解释 ObjectId 的结构、生成方式以及它在 MongoDB 中的应用。 ObjectId 的结…

2024年水利水电安全员考试题库及答案

一、单选题 1.在各类有机电解质之间&#xff0c;其毒性大小排序正确的是&#xff08;&#xff09;。 A.脂肪煙〉醇&#xff1e;酮&#xff1e;环煙〉芳煙 B.脂肪煙&#xff1e;醇&#xff1e;酮〉芳煙〉环煙 C.芳煙〉醇&#xff1e;酮&#xff1e;环煙〉脂肪煙 D.芳煙〉酮…

【C++】函数模板和类模版

目录 前言 模板参数 类型模板参数 非类型模板参数 模板的特化 函数模板的特化 类模板的特化 全特化 偏特化 模板的分离编译 模板总结 前言 函数模板和类模板是C模板编程中的两个核心概念&#xff0c;它们允许程序员编写泛型代码&#xff0c;这些代码可以在多种数据…

月薪70-100k,京东招ML算法工程师和运筹优化专家!

Datawhale分享 推荐&#xff1a;黄玉琳&#xff0c;京东&#xff0c;Datawhale成员 团队介绍 我们是京东零售集团供应链算法优化团队&#xff0c;通过在人工智能与运筹优化领域的持续性技术革新,为京东自营千万级商品提供算法策略支持,实现了以用户为中心的供应链管理和更高效…

常用PromQL语句

常用PromQL语句 1. 查询CPU使用率&#xff1a;2. 查询内存使用率&#xff1a;3. 查询磁盘使用率&#xff1a;4. 查询网络带宽使用率&#xff1a;5. 查询数据库连接数&#xff1a;6. 查询HTTP请求响应时间&#xff1a;7. 查询日志错误数量&#xff1a;8. 查询系统负载&#xff1…

我的创作纪念日-2024年6月10日

机缘 最开始写博客的想法很单纯&#xff0c;记录自己的学习过程在以后可以随时回顾自己需要的知识。 收获 从第一篇博客到现在最明显的变化就是自己做实验和写东西的思路越来越规范了&#xff0c;学习了解实现的东西也更加具体了。通过一篇篇博客我看到了自己在一点点积累&am…

Web前端GIS入门:从基础到实践的全方位探索

Web前端GIS入门&#xff1a;从基础到实践的全方位探索 随着信息技术的飞速发展&#xff0c;地理信息系统&#xff08;GIS&#xff09;已经深入到我们生活的方方面面。而Web前端GIS作为GIS领域的一个重要分支&#xff0c;正逐渐成为开发者和研究者的热门选择。本文将从四个方面…

攻防世界---misc---BotW-

1、下载附件是一张图片 2、查看图片属性&#xff0c;用winhex分析&#xff0c;没有发现奇怪的地方&#xff0c;用binwalk&#xff0c;接着使用foremost 3、得到两张图片&#xff0c;一张是原图&#xff0c;一张是特殊的字符 4、经过查阅资料得知&#xff0c;这是希卡文字&#…

iOS 查看runtime源码的几种方法

目录 前言 查看runtime 源码方法 1.下载 Apple 官方提供的源代码 2.通过 GitHub 访问镜像 3.使用命令行工具查看 4.示例 前言 这篇博客主要介绍了查看iOS runtime源代码的方法。 查看runtime 源码方法 查看iOS runtime源码的方法包括以下几个步骤&#xff1a; 1.下载 A…

IPv6 归属地城市级 Api 接口 - 精准定位每一个连接

随着互联网的快速发展&#xff0c;人们对于网络安全和隐私保护的要求也越来越高。在网络世界中&#xff0c;每一个连接都有其特定的地理位置&#xff0c;了解连接的归属地信息对于识别恶意行为以及网络运营具有重要意义。IPv6 归属地城市级 Api 接口就能够实现对连接的精准定位…

复数乘法IP核的使用

一、IP核解析 在这张图片中&#xff0c;我们看到的是一个“Complex Multiplier (6.0)” IP 核的配置界面。以下是各个配置参数的详细说明&#xff1a; 1.1 Multiplier Construction Use LUTs: 选择这个选项时&#xff0c;乘法器将使用查找表&#xff08;LUTs&#xff09;来实现…