当前位置: 首页 > news >正文

antd react 文件上传只允许上传一个文件且上传后隐藏上传按钮

antd react 文件上传只允许上传一个文件且上传后隐藏上传按钮

  • 效果图
  • 代码解析

效果图

在这里插入图片描述
在这里插入图片描述

代码解析

import { Form, Upload, message } from 'antd';
import { PlusOutlined } from '@ant-design/icons';
import { useState, useEffect } from 'react';
import { BASE_URL } from '@/utils/request';
const FormItemInputUpload = (props) => {const [visble, setVisibel] = useState(false);useEffect(() => {if (props.edit) {setVisibel(true);} else {setVisibel(false);}}, [props]);const normFile = (e) => {if (e.fileList && e.fileList.length == 0) {setVisibel(false);} else {setVisibel(true);}if (Array.isArray(e)) {return e;}return e?.fileList;};const onRemove = (e) => {const urls = [props.form.getFieldValue(props.name)].flat().filter((item) => item != e.response.data[0].imageAddress);props.form.setFieldsValue({[props.name]: urls,});};return (<Form.Itemlabel={props.label}name={props.name}valuePropName="fileList"getValueFromEvent={normFile}rules={props?.rules && [{required: true,validator: (_, value, callback) => {if (!value || value.length == 0) {callback(`请上传${props.label}`);} else {callback();}},},]}><UploadmaxCount={props?.maxCount || 1}action={`${BASE_URL}/cdsj-file/upload`}data={{ minioCatalogEnums: props.sysType }}name="files"headers={{ Authorization: localStorage.getItem('token') }}listType="picture-card"accept=".png,.jpeg,.jpg"beforeUpload={(file) => {const isPNG =file.type == 'image/png' ||file.type == 'image/jpg' ||file.type == 'image/jpeg';if (!isPNG) {message.error('请上传图片格式文件!');}return isPNG || Upload.LIST_IGNORE;}}onRemove={onRemove}>{visble ? null : <PlusOutlined />}</Upload></Form.Item>);
};export default FormItemInputUpload;···
//引用<FormItemInputUploadname="image"label="图片"edit={props?.fillingForm?.image}form={form}sysType="SIGNATURE"rules/>
http://www.lryc.cn/news/168245.html

相关文章:

  • C语言指针进阶(2)
  • 51 单片机 led 灯光操作
  • VSCODE 使用技巧
  • 数据库安全(Mysql,Hadoop,Redis)
  • C【动态内存管理】
  • Javase | 集合-上
  • Multitor:一款带有负载均衡功能的多Tor实例创建工具
  • AIGC专栏6——通过阿里云与AutoDL快速拉起Stable Diffusion和EasyPhoto
  • Mysql的逻辑架构、存储引擎
  • [ES6]模块
  • 物联网终端算法
  • 【面试刷题】——TCP三次握手,以及为什么要三次握手
  • 算法系列-力扣206-单链表反转
  • 网络基础-应用层协议-HTTP/HTTPS
  • problen(5)ubuntu版本问题
  • 写一篇nginx配置指南
  • rhel8防火墙firewalld操作
  • OpenCV项目实战(2)— 如何用OpenCV实现弹球动画
  • golang iris框架 + linux后端运行
  • linux shell操作- 02 常用命令及案例
  • 考研408 | 【计算机组成原理】 数据的表示和运算
  • 【小沐学NLP】AI辅助编程工具汇总
  • linux动态扩容系统盘(非lvm磁盘)
  • Gitlab仓库部署
  • Day46:项目-购物车案例
  • 【小沐学CAD】嵌入式UI开发工具:GL Studio
  • Python:Tornado框架之获取get和post的传参
  • JSON和全局异常处理
  • 骨传导耳机有害处吗、骨传导耳机真的不好用吗?
  • 第一类曲面积分:曲面微元dσ与其投影面积微元dxdy之间的关系推导