import React, { useState } from 'react'; import { UploadOutlined } from '@ant-design/icons'; import { Button, message, Upload } from 'antd'; import type { RcFile, UploadFile, UploadProps } from 'antd/es/upload/interface'; const App: React.FC = () => { const [fileList, setFileList] = useState([]); const [uploading, setUploading] = useState(false); const handleUpload = () => { const formData = new FormData(); fileList.forEach((file) => { formData.append('files[]', file as RcFile); }); setUploading(true); // You can use any AJAX library you like fetch('https://run.mocky.io/v3/435e224c-44fb-4773-9faf-380c5e6a2188', { method: 'POST', body: formData, }) .then((res) => res.json()) .then(() => { setFileList([]); message.success('upload successfully.'); }) .catch(() => { message.error('upload failed.'); }) .finally(() => { setUploading(false); }); }; const props: UploadProps = { onRemove: (file) => { const index = fileList.indexOf(file); const newFileList = fileList.slice(); newFileList.splice(index, 1); setFileList(newFileList); }, beforeUpload: (file) => { setFileList([...fileList, file]); return false; }, fileList, }; return ( <> ); }; export default App;