一个小的可编辑表格问题引起的思考

news2025/2/23 4:02:39

11.21工作中遇到的问题

预期:当每行获取红包金额的时候若出现错误,右侧当行会出现提示

结果:获取红包金额出现错误,右侧对应行并没有出现错误提示

我发现,当我们设置readonly的时候,其实render函数依旧是触发了的,右侧图片中的log被成功打印出来了,可以验证,所以可以粗略说明,records被更改,触发了table,以及当前行的渲染,可为什么提示的数据依旧不变

接下来,我用一个简单的demo也复现了这个问题
在这里插入图片描述
在这里插入图片描述

将readonly: true替换成editable: false,居然就成功了,这与我之前对于readonly和editable的认知有了太大的差距

在这里插入图片描述

扩展:readonly和editable的区别

查找dom元素,发现当我设置editable:false的时候,包裹tips的dom标签是ant-table-cel,一个表格元素,但是当设置readonly: true的时候,包裹tips的dom标签是一个表单元素,通过样式class:ant-form-item-control-input-content,可以猜测目前的包裹tips的dom多半是一个受控的input表单

在这里插入图片描述

继而,通过阅读pro component中editabe的源码,找到了关键点,对于受控模式下的组件,需要触发onchange,而在代码中触发表单的onchange的条件,由props.controlled控制,这也是为啥我设置readonly:true的时候,没有看见tips更新,即使表格的datasource更新了

在这里插入图片描述

在这里插入图片描述

所以得到另一种解决方法,

在这里插入图片描述

在这里插入图片描述

总结

readonly设置为true,编辑表格的form会收集这个字段的值;但是会变成一个受控的不可编辑的input表单项,若去要更新表单,需要controlled设置为true,这样每次value更新的时候都会重置表单了

若设置 editable: false, form不会收集这个字段值,但是依旧是个table-cell

问题Code如下

import { EditableProTable } from "@ant-design/pro-components";
import { useState } from "react";
import { Columns } from "./columns";

const rowKey = 'productId';
const EditTable = ()=>{
    const [data, setData] = useState([
      {
        productId: '1',
      },
      {
        productId: '2',
      },
    ]);
    const [editableKeys, setEditableRowKeys] = useState(() => []);
    const [failTips, setFailTips] = useState<any>([]);
    const changeFailInfo = (curFailTips: any) =>{
        const uniqueFailTips = [...new Set([...failTips, ...curFailTips].map(item => JSON.stringify(item)))].map(item => JSON.parse(item));
        
        setFailTips(uniqueFailTips)
        const failList = uniqueFailTips.map((item) => item.productId)
        // 将有错误提示的当前行的failTips字段赋值
        const temp = JSON.parse(JSON.stringify(data));
        failList.forEach((item)=>{
            if(data.find((item2:any)=>item2.productId === item)){
                temp.find((item2:any)=>item2.productId === item).failTips = uniqueFailTips.find(item2=>item2.productId === item).failDesc
            }
        })
        setData(temp);
    }
    return (
      <>
        <EditableProTable
          rowKey={rowKey}
          columns={Columns(changeFailInfo,failTips)}
          scroll={{ x: 1000 }}
          bordered
          value={data}
          recordCreatorProps={false}
          editable={{
            type: 'multiple',
            editableKeys: data.map((item) => item[rowKey]),
            onChange: setEditableRowKeys,
          }}
          tableAlertRender={false}
        />
      </>
    );
}

export default EditTable

export const Columns = (changeFailInfo: any, failTips: any) => [
  {
    title: 'productId',
    key: 'productId',
    dataIndex: 'productId',
    field: 'productId',
    headerStyle: { fontSize: 14 },
    colSize: 0,
    width: 100,
    readonly: true, 
  },

  {
    title: '期望',
    key: 'Money',
    dataIndex: 'Money',
    editor: 'input-editor',
    width: 100,
    editable: true,
    colSize: 1.5,
    headerStyle: { fontSize: 14, autoWrapText: true },
    fieldProps: (form, { entity, rowKey }) => {
      return {
        onBlur: async (e) => {
          const { productId } = entity;
          const value = e.target.value || 0;
          if (value == 0) return;

          changeFailInfo([{ productId, failDesc: 'tips' }]);
        },
      };
    },
  },
  {
    title: '提示',
    key: 'failTips',
    dataIndex: 'failTips',
    editable: false,
    //readonly: true,
    align: 'center',
    fixed: 'right',
    width: 200,
    hideInTable: !failTips.length,
    renderText: (_: any, record: any) => {
      console.log(record, 'yts_change');
      return <span style={{ color: 'red' }}>{record.failTips}</span>;
    },
  },
];

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

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

相关文章

【Linux课程学习】:进程描述---PCB(Process Control Block)

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;Linux课程学习 &#x1f337;追光的人&#xff0c;终会万丈光芒 &#x1f389;欢迎大家点赞&#x1f44d;评论&#x1f4dd;收藏⭐文章 目录 1.基本概念&#xff1a; &#x1f95d;进程的…

java基础概念36:正则表达式1

一、正则表达式的作用 作用一&#xff1a;校验字符串是否满足规则&#xff1b;作用二&#xff1a;在一段文本中查找满足要求的内容。——爬虫 二、正则表达式 2-1、字符类 示例&#xff1a; public static void main(String[] args) {System.out.println("a".matc…

设计模式之 命令模式

命令模式&#xff08;Command Pattern&#xff09;是行为型设计模式之一&#xff0c;它将请求&#xff08;或命令&#xff09;封装成一个对象&#xff0c;从而使用户能够将请求发送者与请求接收者解耦。通过命令模式&#xff0c;调用操作的对象与执行操作的对象不直接关联&…

GRU (门控循环单元 - 基于RNN - 简化LSTM又快又好 - 体现注意力的思想) + 代码实现 —— 笔记3.5《动手学深度学习》

目录 0. 前言 1. 门控隐状态 1.1 重置门和更新门 1.2 候选隐状态 1.3 隐状态 2. 从零开始实现 2.1 初始化模型参数 2.2 定义模型 2.3 训练与预测 3 简洁实现 4. 小结 0. 前言 课程全部代码&#xff08;pytorch版&#xff09;已上传到附件看懂上一篇RNN的所有细节&am…

实践篇:青果IP助理跨境电商的高效采集

写在前面&#xff1a; 近年来&#xff0c;跨境电商行业迅速崛起&#xff0c;成为全球贸易的重要组成部分。据市场调研机构Statista数据显示&#xff0c;2024年全球跨境电商市场规模预计将突破5万亿美元&#xff0c;覆盖数十亿消费者。跨境电商的竞争日益激烈&#xff0c;商家不…

电子应用设计方案-16:智能闹钟系统方案设计

智能闹钟系统方案设计 一、系统概述 本智能闹钟系统旨在为用户提供更加个性化、智能化和便捷的闹钟服务&#xff0c;帮助用户更有效地管理时间和起床。 二、系统组成 1. 微控制器 - 选用低功耗、高性能的微控制器&#xff0c;如 STM32 系列&#xff0c;负责整个系统的控制和数据…

QML —— 3种等待指示控件(附源码)

效果如下 说明 BusyIndicator应用于指示在加载内容或UI被阻止等待资源可用时的活动。BusyIndicator类似于一个不确定的ProgressBar。两者都可以用来指示背景活动。主要区别在于视觉效果,ProgressBar还可以显示具体的进度(当可以确定时)。由于视觉差异,繁忙指示器和不确定的…

Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)

链接 链接2 这两道题略微有点难&#xff0c;其中第一道题我自己解出来了&#xff0c;还补充了一个更好的解法&#xff0c;在空间上做了优化。 第二道题看了别人的题解&#xff0c;我正在努力理解。 题目一&#xff1a; 题意&#xff1a;为什么有n个元素&#xff0c;但是还有…

通过轻易云平台实现聚水潭数据高效集成到MySQL的技术方案

聚水潭数据集成到MySQL的技术案例分享 在本次技术案例中&#xff0c;我们将详细探讨如何通过轻易云数据集成平台&#xff0c;将聚水潭的数据高效、可靠地集成到MySQL数据库中。具体方案为“聚水谭-店铺查询单-->BI斯莱蒙-店铺表”。这一过程不仅需要处理大量数据的快速写入…

华为云容器监控平台

首先搜索CCE,点击云容器引擎CCE 有不同的测试&#xff0c;生产&#xff0c;正式环境 工作负载--直接查询服务名看监控 数据库都是走的一个 Redis的查看

机器学习系列----关联分析

目录 1. 关联分析的基本概念 1.1定义 1.2常用算法 2.Apriori 算法的实现 2.1 工作原理 2.2 算法步骤 2.3 优缺点 2.4 时间复杂度 2.5实际运用----市场购物篮分析 3. FP-Growth 算法 3.1 工作原理 3.2 算法步骤 3.3 优缺点 3.4 时间复杂度 3.5实际运用——网页点…

前端面试vue篇:Vue2 和 Vue3 在设计和性能上有显著区别

Vue3 相对于 Vue2 的主要改进和性能提升体现在以下几个关键领域 1.响应式系统&#xff1a; (1)Vue2 使用 Object.defineProperty 遍历对象的所有属性来实现响应式&#xff0c;这在大型应用中可能导致性能瓶颈&#xff0c;尤其是在组件初次渲染和大量数据变化时。 (2)Vue3 引入了…

Cisco Catalyst 9800-40 Wireless Controller配置修改以及状态信息查看操作指引

1、查看AP的个性化信息、如IP地址、序列号、射频信息、信道信息、干扰等等AP信息 点击Monitoring---->AP Statistics---->找到想看的AP&#xff0c;点击进去查看 可以看得到IP地址、AP型号、POWER的状态、版本号、boot版本号、UP time时间和LED状态灯等等 继续往下拉可以…

k8s集群加入node节点为ubuntu 22.04

文章目录 1.环境准备1.1 关闭无用服务1.2 环境和网络1.3 apt源1.4 系统优化 2. 装containerd3. 接入k8s集群3.1 kubelet、kubeadm、kubectl安装3.2 缺少一个镜像3.3 接入k8s集群 4. 一些相关问题 1.环境准备 rootcto-gpu-pro-n01:~# lsb_release -a No LSB modules are availa…

低速接口项目之串口Uart开发(七)——如何在FPGA项目中实现自适应波特率串口功能

本节目录 一、自适应波特率串口 二、自适应波特率串口设计思路 三、自适应波特率串口测试验证 四、往期文章链接本节内容 一、自适应波特率串口 串口波特率Baud,具体定义此处不再进行描述&#xff0c;常用的波特率数值有115200、57600、38400、19200、9600等&#xff0c;FPG…

JS中的正则表达式简要梳理

文章目录 一、结构1、匹配模式2、字符组3、量词4、贪婪匹配和惰性匹配5、多选分支6、匹配模式关键词 二、位置1、位置锚点 三、括号分组1、分组2、分支结构3、引用分组4、括号嵌套 四、回溯模式1、回溯匹配 正则表达式&#xff08;Regular Expression&#xff09;‌是一种强大的…

【风水】-- 买车和用车的风水知识

目录 一、阴阳与车的风水 1. 车的属性&#xff1a;阴阳平衡 2. 车主与车的阴阳互补 二、五行与车的风水 1. 车的颜色与五行 2. 车主的五行与车的五行匹配 3. 五行相生相克的应用 三、八卦与车的风水 1. 车位选择与八卦方位 2. 车内布置与八卦 四、总结 结合阴阳、五…

深度剖析Linux进程控制

文章目录 &#x1f355;前言&#x1f95d;进程创建fork 函数fork函数返回值写时拷贝fork 使用场景fork调用失败的原因 &#x1f965;进程终止进程退出码进程正常退出return 退出exit 函数_exit 函数return VS exit VS _exit 进程异常退出 &#x1f347;进程等待进程等待的必要性…

网络安全,文明上网(6)网安相关法律

列举 1. 《中华人民共和国网络安全法》&#xff1a; - 这是中国网络安全的基本法律&#xff0c;于2017年6月1日开始实施。该法律明确了网络运营者的安全保护义务&#xff0c;包括采取数据分类、重要数据备份和加密等措施。 2. 《中华人民共和国数据安全法》&#xff1a; …

IDEA2023 SpringBoot整合MyBatis(三)

一、数据库表 CREATE TABLE students (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100) NOT NULL,age INT,gender ENUM(Male, Female, Other),email VARCHAR(100) UNIQUE,phone_number VARCHAR(20),address VARCHAR(255),date_of_birth DATE,enrollment_date DATE,cours…