React + antd Upload组件弹出文件框前进行检查

有一个需求,需要上传文件,但是在上传文件之前希望能先检查用户能否上传(权限或者证书等校验) 上传文件前端用的开发框架是React, 组件库使用Ant Design,所以上传文件选择使用Upload组件。

最开始看文档是打算beforeUpload的,文档中具体说明是:

上传文件之前的钩子,参数为上传的文件,若返回 false 则停止上传。支持返回一个 Promise 对象,Promise 对象 reject 时则停止上传,resolve 时开始上传( resolve 传入 FileBlob 对象则上传 resolve 传入对象);也可以返回 Upload.LIST_IGNORE,此时列表中将不展示此文件。 注意:IE9 不支持该方法

这里将文件上传的步骤简化描述下,分为三步:用户点击按钮------弹出文件选择框选择文件------上传文件

beforeUpload是在上传文件之前调用的,也就是在弹出文件选择框选择文件之后,上传文件支持。实际测试也是如何,在弹出文件选择框后,beforeUpload才被调用

而我希望实现的效果是在用户点击按钮后就进行检查,检查通过后才弹出文件选择框,所以beforeUpload不能用。

后面考虑了两个方案:

  1. 隐藏掉UploadButton,显式另一个Button,点击该按钮时进行检查,检查通过后在通过代码调用UploadButtonclick()触发上传操作
  2. Upload有提供openFileDialogOnClick属性,将其设置为false可以不弹出文件框。所以可以考虑先将其设置为false,然后给Upload的按钮增加点击事件,在里面先做检查,检查通过后将openFileDialogOnClick设置为true,然后再触发click()

第一个方案需要增加一个Button,第二个方案则需要设置openFileDialogOnClick,两个方案都需要在事件里面再触发click()

最后选择了第二个方案来实现,具体实现代码如下

typescript 复制代码
import React, {useEffect, useState, useRef} from "react";
import {PageHeaderWrapper} from "@ant-design/pro-layout";
import {Button, Card, Col, message, Row, Upload} from "antd";

const UpdateManage: React.FC = () => {

	const [openFileDialog, setOpenFileDialog] = useState<boolean>(false)
	const uploadButtonRef = useRef()
	
	async function doCheckLicense() {
		// do something ...
	}

	return (
	<PageHeaderWrapper>
		<Card>
			<Row gutter={[8, 16]} style={{marginBottom: 20}}>
				<Col span={3}>
					<Upload
		              name = 'file'
		              openFileDialogOnClick={openFileDialog}
		              showUploadList={false}
		             >						
			             <Button
				           type="primary"
			               onClick={()=>{                  
			                  if(openFileDialog == false){
			                    doCheck().then(res => {
			                      if(res.success) {
			                        setOpenFileDialog(true)
			                        setTimeout(() => {
				                        uploadButtonRef.current.click()
				                      }, 50)
			                      } else {
			                        message.error("not pass check")
			                      }
			                    }).catch((error) => {
				                   message.error("error")
			                    })
			                  }                
			                }}
		                  ref={uploadButtonRef}
                        >Upload</Button>
		             </Upload>
				</Col>
			</Row>
		</Card>
	</PageHeaderWrapper>
	)
}

export default UpdateManage
相关推荐
是上好佳佳佳呀3 分钟前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
你真的快乐吗18 分钟前
@fuxishi/svg-icon:一个 Vue 3 svg本地图标+iconify图标组件库,让图标管理不再头疼
前端·vue.js·typescript
Rkgua23 分钟前
ESModule和Commonjs模块的区别
前端·javascript
江南十四行24 分钟前
ReAct Agent 基本理论与项目实战(二)
前端·react.js·前端框架
用户6000718191030 分钟前
【翻译】React 如何乱序流式输出 UI,却仍保持最终顺序
前端
江南十四行40 分钟前
AI Agent应用类型及Function Calling开发实战(三)
服务器·前端·javascript
GISer_Jing42 分钟前
AI原生全栈架构理论体系:从分布式范式演进到全链路工程化理论基石
前端·人工智能·学习·ai编程
GISer_Jing1 小时前
从“切图仔”到“增长架构师”:AI时代营销前端的范式革命
前端·人工智能·ai编程
广州华水科技1 小时前
单北斗GNSS在水库变形监测中的应用与系统安装解析
前端
xingpanvip1 小时前
星盘接口开发文档:组合三限盘接口指南
android·开发语言·前端·python·php·lua