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

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 (<><EditableProTablerowKey={rowKey}columns={Columns(changeFailInfo,failTips)}scroll={{ x: 1000 }}borderedvalue={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.mzph.cn/bicheng/61635.shtml

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

相关文章

高效集成:金蝶盘亏单数据对接管易云

金蝶盘亏单数据集成到管易云的技术实现 在企业日常运营中&#xff0c;数据的高效流转和准确对接是确保业务顺利进行的关键。本文将聚焦于一个具体的系统对接集成案例&#xff1a;如何将金蝶云星空中的盘亏单数据无缝集成到管易云的其他出库模块。 为了实现这一目标&#xff0…

神经网络问题之一:梯度消失(Vanishing Gradient)

梯度消失&#xff08;Vanishing Gradient&#xff09;问题是深度神经网络训练中的一个关键问题&#xff0c;它主要发生在反向传播过程中&#xff0c;导致靠近输入层的权重更新变得非常缓慢甚至几乎停滞&#xff0c;严重影响网络的训练效果和性能。 图1 在深度神经网络中容易出现…

单神经元 PID 解耦控制

单神经元 PID 解耦控制是一种将单神经元自适应控制与解耦控制相结合的方法&#xff0c;适用于多输入多输出&#xff08;MIMO&#xff09;系统。其核心是利用单神经元的自适应能力实现 PID 参数在线调整&#xff0c;同时通过解耦策略减少变量之间的相互影响&#xff0c;提高控制…

数据库类型介绍

1. 关系型数据库&#xff08;Relational Database, RDBMS&#xff09;&#xff1a; • 定义&#xff1a;基于关系模型&#xff08;即表格&#xff09;存储数据&#xff0c;数据之间通过外键等关系相互关联。 • 特点&#xff1a;支持复杂的SQL查询&#xff0c;数据一致性和完整…

线性回归 - 最小二乘法

线性回归 一 简单的线性回归应用 webrtc中的音视频同步。Sender Report数据包 NTP Timestamp&#xff08;网络时间协议时间戳&#xff09;&#xff1a;这是一个64位的时间戳&#xff0c;记录着发送SR的NTP时间戳&#xff0c;用于同步不同源之间的时间。RTP Timestamp&#xff1…

AWD脚本编写_1

AWD脚本编写_1 shell.php&#xff08;放在网站根目录下&#xff09; <?php error_reporting(0); eval($_GET["yanxiao"]); ?>脚本编写成功 后门文件利用与解析 import requests import base64def get_flag(url, flag_url, method, passwd, flag_path):cmd…

Linux环境基础开发工具的使用(yum、vim、gcc、g++、gdb、make/Makefile)

目录 Linux软件包管理器 - yum Linux下安装软件包的方式 认识yum 查找软件包 安装软件 如何实现本地机器和云服务器之间的文件互传 卸载软件 Linux编辑器 - vim vim的基本概念 vim下各模式的切换 批量化注释 vim的简单配置 Linux编译器 - gcc/g gcc/g的作用 gcc/g语…

IDEA如何设置编码格式,字符编码,全局编码和项目编码格式

前言 大家好&#xff0c;我是小徐啊。我们在开发Java项目&#xff08;Springboot&#xff09;的时候&#xff0c;一般都是会设置好对应的编码格式的。如果设置的不恰当&#xff0c;容易造成乱码的问题&#xff0c;这是要避免的。今天&#xff0c;小徐就来介绍下我们如何在IDEA…

【Redis】实现点赞功能

一、实现笔记点赞 使用redis实现点赞功能&#xff0c;对于一个笔记来说&#xff0c;不同用户只能是点赞和没点赞&#xff0c;点赞过的笔记再点击就应该取消点赞&#xff0c;所以实际上根据需求&#xff0c;我们只需要将点赞的数据存到对应的笔记里&#xff0c;查看对应的笔记相…

InstantStyle容器构建指南

一、介绍 InstantStyle 是一个由小红书的 InstantX 团队开发并推出的图像风格迁移框架&#xff0c;它专注于解决图像生成中的风格化问题&#xff0c;旨在生成与参考图像风格一致的图像。以下是关于 InstantStyle 的详细介绍&#xff1a; 1.技术特点 风格与内容的有效分离 &a…

Redisson学习教程(B站诸葛)

弱智级别 package org.example.controller;public class IndexController {Autowiredprivate Redisson redisson;Autowiredprivate StringRedisTemplate stringRedisTemplate;RequestMapping("/deduct_storck")public String deductStock() {String lockKey "…

蓝桥杯每日真题 - 第19天

题目&#xff1a;&#xff08;费用报销&#xff09; 题目描述&#xff08;13届 C&C B组F题&#xff09; 解题思路&#xff1a; 1. 问题抽象 本问题可以看作一个限制条件较多的优化问题&#xff0c;核心是如何在金额和时间约束下选择最优方案&#xff1a; 动态规划是理想…

科研实验室的数字化转型:Spring Boot系统

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理实验室管理系统的相关信息成为必然。开发合…

【Redis】持久化机制RDB与AOF

一、RDB RDB模式是就是将内存中的数据存储到磁盘中&#xff0c;等到连接断开的时候会进行持久化操作。但是如果服务器宕机&#xff0c;会导致这个持久化机制不会执行&#xff0c;但是内存中的文件会直接丢失。所以可以设置一个触发机制&#xff0c;save 60 1000 就是代表60秒 执…

Excel——宏教程(精简版)

一、宏的简介 1、什么是宏&#xff1f; Excel宏是一种自动化工具&#xff0c;它允许用户录制一系列操作并将其转换为VBA(Visual Basic for Applications)代码。这样&#xff0c;用户可以在需要时执行这些操作&#xff0c;以自动化Excel任务。 2、宏的优点 我们可以利用宏来…

【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段

文章目录 一、MyBatis-Plus简介二、快速入门1、环境准备2、将mybatis项目改造成mybatis-plus项目&#xff08;1&#xff09;引入MybatisPlus依赖&#xff0c;代替MyBatis依赖&#xff08;2&#xff09;配置Mapper包扫描路径&#xff08;3&#xff09;定义Mapper接口并继承BaseM…

【spring】spring单例模式与锁对象作用域的分析

前言&#xff1a;spring默认是单例模式&#xff0c;这句话大家应该都不陌生&#xff1b;因为绝大多数都是使用单例模式&#xff0c;避免了某些问题&#xff0c;可能导致对某些场景缺乏思考。本文通过结合lock锁将单例模式、静态变量、锁对象等知识点串联起来。 文章目录 synchr…

Cyberchef使用功能之-多种压缩/解压缩操作对比

cyberchef的compression操作大类中有大量的压缩和解压缩操作&#xff0c;每种操作的功能和区别是什么&#xff0c;本章将进行讲解&#xff0c;作为我的专栏《Cyberchef 从入门到精通教程》中的一篇&#xff0c;详见这里。 关于文件格式和压缩算法的理论部分在之前的文章《压缩…

Elasticsearch开启认证及kibana密码登陆

Elasticsearch不允许root用户运行,使用root用户为其创建一个用户es,为用户es配置密码,并切换到es用户。 adduser elastic passwd elastic su elasticElasticsearch(简称ES)是一个基于Lucene的搜索服务器。它提供了一个分布式、多用户能力的全文搜索引擎,基于RESTful web…

C++初阶学习第十一弹——list的用法和模拟实现

目录 一、list的使用 二.list的模拟实现 三.总结 一、list的使用 list的底层是双向链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立节点中&#xff0c;在节点中通过指针指向 其前一个元素和后一个元素。 常见的list的函数的使用 std::list<int> It {1,…