react+antd中做一个外部按钮新增 表格内部本地新增一条数据并且支持编辑删除(无难度上手)

需求背景

做一个可以外部控制新增刷新表格  表格内部可以编辑删除 类似下方需求图

实现过程

因为我实现时有两个这样的表格  所以我的事件里面会有传参用于判断  可忽略传参判断部分   代码中有formatMessage部分为国际化可忽略 

 <div style={{ marginBottom: '10px', marginTop: '10px', display: 'flex' }}><Button type={'primary'} onClick={() => handleAddWhiteList(1)}>{formatMessage({ id: 'button.Add' })}</Button><Buttontype={'primary'}style={{ marginLeft: '10px' }}onClick={() => onRefreshWhiteList(1)}icon={<SyncOutlined />}/></div><Tablesize="small"columns={whiteColumns}dataSource={whiteDataSource}pagination={false}bordered={true}rowKey={'id'}scroll={{y: whiteDataSource?.length > 3 ? 55 * 3 : undefined, // 动态计算高度}}/>//js部分const [whiteDataSource, setWhiteDataSource] = useState([]);//白名单列表const whiteColumns = [{title: 'HOST',dataIndex: 'url',render: (text, record) => {return (<Inputvalue={record.url}disabled={record.disabled}onBlur={(e) => handleUrlBlur(e, record.id, 1)}onChange={(e) => handleUrlWhitleChange(e, record.id, 1)}placeholder={formatMessage({ id: 'label.rollCall.PleaseEnter' })}/>);},},{title: formatMessage({ id: 'label.Operation' }),dataIndex: 'operation',width: 120,render: (text, record) => {return (<Space size={'middle'}><TableButtononClick={() => handleEdit(1, record)}disabled={!record.disabled}icon={<IconBtnitemInfo={{ itemId: 'edit', title: formatMessage({ id: 'button.Edit' }) }}/>}/><TableButtonconfirmconfirmMsg={formatMessage({ id: 'confirm.Delete' })}onConfirm={() => handleDel(1, record)}icon={<IconBtnitemInfo={{ itemId: 'delete', title: formatMessage({ id: 'button.Delete' }) }}/>}/></Space>);},},];const handleAddWhiteList = (num) => {if (num == 1) {setWhiteDataSource([...whiteDataSource,{ url: '', id: Date.now(), disabled: false, error: null },]);} else {setBlackDataSource([...blackDataSource,{ url: '', id: Date.now(), disabled: false, error: null },]);}};const onRefreshWhiteList = (num) => {if (num == 1) {setWhiteDataSource(whiteDataSource.filter((item) => item.url !== ''));} else {setBlackDataSource(blackDataSource.filter((item) => item.url !== ''));}};//名单失焦事件const handleUrlBlur = (e, id, num) => {if (num == 1) {const newData = whiteDataSource.map((item) => {if (item.id === id) {return { ...item, disabled: true };}return item;});setWhiteDataSource(newData);} else {const newData = blackDataSource.map((item) => {if (item.id === id) {return { ...item, disabled: true };}return item;});setBlackDataSource(newData);}};//名单输入事件const handleUrlWhitleChange = (e, id, num) => {if (num == 1) {const newData = whiteDataSource.map((item) => {if (item.id === id) {return { ...item, url: e.target.value };}return item;});setWhiteDataSource(newData);} else {const newData = blackDataSource.map((item) => {if (item.id === id) {return { ...item, url: e.target.value };}return item;});setBlackDataSource(newData);}};
//  编辑处理函数const handleEdit = (num, record) => {if (num == 1) {setWhiteDataSource((prev) =>prev.map((item) => (item.id === record.id ? { ...item, disabled: false } : item)),);} else {setBlackDataSource((prev) =>prev.map((item) => (item.id === record.id ? { ...item, disabled: false } : item)),);}};//删除处理const handleDel = (num, record) => {if (num == 1) {setWhiteDataSource((prev) => prev.filter((item) => item.id !== record.id));} else {setBlackDataSource((prev) => prev.filter((item) => item.id !== record.id));}};

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

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

相关文章

【深度学习新浪潮】视觉与多模态大模型文字生成技术研究进展与产品实践

一、研究进展 跨模态架构创新 原生多模态模型:微软KOSMOS系列通过统一框架支持文本、图像、语音等多模态输入输出,实现跨模态推理与迁移。例如,KOSMOS-2.5可处理文本密集图像,生成结构化文本描述,并通过重采样模块优化视觉与语言的对齐。混合专家架构:第三代模型(如Deep…

重生之我是去噪高手——diffusion model

diffusion model是如何运作的&#xff1f; 想象一下&#xff0c;你有一张清晰的图片。扩散模型的核心思想分为两个过程&#xff1a; 前向过程&#xff08;Forward Process / Diffusion Process&#xff09;&#xff1a;逐步加噪反向过程&#xff08;Reverse Process / Denois…

华为项目管理“六步一法”方法论全解析:目标确认、项目活动分解与日事清系统协同

大家都知道&#xff0c;项目管理在现在各个行业里都是越来越重要了。 要是搞不好&#xff0c;项目就会拖沓&#xff0c;甚至走向失败。 今天咱们就来聊聊华为是怎么做项目管理的&#xff0c;比较知名的就是它们的“六步一法”。华为通过“六步一法”来进行项目管理&#xff0…

OpenCV 图形API(9)用于执行矩阵与标量之间的逐元素除法操作函数divC()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 矩阵除以标量。 该函数 divC 将矩阵 src 的每个元素除以给定的标量值&#xff1a; dst(I) saturate(src(I)*scale/divisor) \texttt{dst(I) s…

单例模式(懒汉模式/饿汉模式)

相关概念参考&#xff1a;【C】C 单例模式总结&#xff08;5种单例实现方法&#xff09;_单例模式c实现-CSDN博客 #include<iostream>class LazySingle{ public:static LazySingle& getInstance(){static LazySingle instance;return instance;}void hello(){std::c…

RocketMQ初认识

ProducerCustomerNameServer: Broker的注册服务发现中心BrokerServer:主要负责消息的存储、投递和查询以及服务高可用保证 RocketMQ的集群部署&#xff1a; 单个master的分支多个Master 模式&#xff1a;集群中有多个 Master 节点&#xff0c;彼此之间相互独立。生产者可以将消…

Maven/Gradle的讲解

一、为什么需要构建工具? 在理解 Maven/Gradle 之前,先明确它们解决的问题: ​​依赖管理​​:项目中可能需要引入第三方库(如 Spring、JUnit 等),手动下载和管理这些库的版本非常麻烦。​​标准化构建流程​​:编译代码、运行测试、打包成 JAR/WAR 文件等步骤需要自动…

基于SSM的车辆管理系统的设计与实现(代码+数据库+LW)

摘要 当下&#xff0c;正处于信息化的时代&#xff0c;许多行业顺应时代的变化&#xff0c;结合使用计算机技术向数字化、信息化建设迈进。以前企业对于车辆信息的管理和控制&#xff0c;采用人工登记的方式保存相关数据&#xff0c;这种以人力为主的管理模式已然落后。本人结…

嵌入式硬件篇---JSON通信以及解析

文章目录 前言一、JSON特点语法简单数据格式灵活轻量化跨语言使用二、JSON数据结构对象数组三、JSON在单片机之间通信的应用数据封装与传输四、JSON示例代码五、JSON在上位机与单片机之间通信的应用数据交互六、JSON示例代码七、JSON解析与生成解析生成八、Python中的数据解析1…

【C#】.net core 6.0 依赖注入常见问题之一,在构造函数使用的类,都需要注入到容器里,否则会提示如下报错,让DeepSeek找找原因,看看效果

&#x1f339;欢迎来到《小5讲堂》&#x1f339; &#x1f339;这是《C#》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。&#x1f339; &#x1f339;温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff01;&#…

《P1072 [NOIP 2009 提高组] Hankson 的趣味题》

题目描述 Hanks 博士是 BT&#xff08;Bio-Tech&#xff0c;生物技术) 领域的知名专家&#xff0c;他的儿子名叫 Hankson。现在&#xff0c;刚刚放学回家的 Hankson 正在思考一个有趣的问题。 今天在课堂上&#xff0c;老师讲解了如何求两个正整数 c1​ 和 c2​ 的最大公约数…

nginx的自动跳转https

mkdir /usr/local/nginx/certs/ 创建一个目录 然后用openssl生成证书 编辑nginx的配置文件 自动跳转成功 做一个优化&#xff0c;如果访问的时候后面加了其他的uri也一起自动跳转了

力扣刷题——508.出现次数最多的子树和

给你一个二叉树的根结点 root &#xff0c;请返回出现次数最多的子树元素和。如果有多个元素出现的次数相同&#xff0c;返回所有出现次数最多的子树元素和&#xff08;不限顺序&#xff09;。 一个结点的 「子树元素和」 定义为以该结点为根的二叉树上所有结点的元素之和&…

2025/4/2 心得

第一题 题目描述 给定1001个范围在[1,1000]的数字&#xff0c;保证只有1个数字重复出现2次&#xff0c;其余数字只出现1次。试用O(n)时间复杂度来求出出现2次的这个数字。 不允许用数组 输入格式 第一行&#xff1a;一个整数1001&#xff1b; 第二行&#xff1a;1001个用…

0基础 | 硬件 | NE555芯片 二

目录 “双稳态电路之按键开关LED” 版本一&#xff1a; 版本二&#xff1a; “单稳态电路之延时自动关” 版本一 “无稳态电路之延时自动开关” 版本一&#xff1a; 版本二 “双稳态电路之按键开关LED” 版本一&#xff1a; 按键1 使2脚输入低电平&#xff0c;则3输出…

Python实现链接KS3,并将文件数据上传到KS3

前言 本文是该专栏的第55篇,后面会持续分享python的各种干货知识,值得关注。 说到KS3,首先想到的是金山云提供的对象存储服务。 相信或多或少的同学,在工作项目中也会遇到KS3相关的需求。比如说,现在有大批量的数据文件需要通过Python,上传到KS3中。对此,需要怎么去做…

小白 解析thingsboard 规则链节点

目录 1、filter(筛选器)节点内容 1. Alarm Status Filter(报警状态过滤器) 2. Check Fields Presence(检查字段存在性过滤器) 3. Check Relation Presence(检查关系存在性过滤器) 4. Entity Type Filter(实体类型过滤器) 5. Message Type Filter(消息类型过滤器…

PgVectore的使用

PgVectore的使用 一、PgVector的安装 参照博客&#xff1a;https://blog.csdn.net/u012953777/article/details/147013691?spm1001.2014.3001.5501 二、PgVector的使用 1、创建表与插入数据​ ​​定义向量字段​​&#xff1a; CREATE TABLE items (id SERIAL PRIMARY …

python爬虫爬取淘宝热销(热门)男装商品信息(课程设计;提供源码、使用说明文档及相关文档;售后可联系博主)

TOC 本文仅为记录学习轨迹&#xff0c;如有侵权,联系删除 一、环境说明 使用前必须检查以下环境 &#xff08;1&#xff09;python编译环境 &#xff08;2&#xff09;python脚本执行所需要的库&#xff0c;具体看代码&#xff08;main.py&#xff09;import导入的部分库 &a…

C++ 排序(1)

以下是一些插入排序的代码 1.插入排序 1.直接插入排序 // 升序 // 最坏&#xff1a;O(N^2) 逆序 // 最好&#xff1a;O(N) 顺序有序 void InsertSort(vector<int>& a, int n) {for (int i 1; i < n; i){int end i - 1;int tmp a[i];// 将tmp插入到[0,en…