react + pro-components + ts完成单文件上传和批量上传

上传部分使用的是antd中的Upload组件,具体如下:

GradingFilingReportUpload方法是后端已经做好文件流,前端只需要调用接口即可

单文件上传

javascript 复制代码
<Upload
    key={`upload_${record.id}`}
    showUploadList={false}
    accept=".xlsx"
    maxCount={1}
    customRequest={({ file }) => {
        const formData = new FormData();
        formData.append('id', record.id);
        formData.append('ins', file);
        GradingFilingReportUpload(formData).then(res => {
            if (res.state === 200) {
                message.success(res.message);
            } else {
                message.error('上传失败');
            }
        })
    }}
><a >上传</a></Upload>

多文件上传

页面组件

html 复制代码
<Upload
    showUploadList={false}
    multiple
    customRequest={({ file, onSuccess, onError }) => {
        handleRequestAllFile([file]).then(() => onSuccess && onSuccess('上传成功')).catch(() => onError)
    }}
>
    <a >批量上传</a>
</Upload>

js逻辑

javascript 复制代码
    const handleRequestAllFile = async (fileList: any[]) => {
        try {
            const formData = new FormData();
            fileList.forEach((file) => {
                formData.append('ins', file);
            })
            const res = await GradingFilingReportUpload(formData);
            if (res.state === 200) {
                message.success('文件上传成功');
            } else {
                message.error('文件上传失败');
            }
        } catch (e) {
            message.error('文件上传过程出错')
        }
    }

完整页面代码

javascript 复制代码
import { downLoad, downLoadStream } from '@/util/request';
import { ProTable } from '@ant-design/pro-components';
import { getTableColumns } from './colums'
import { useEffect, useRef, useState } from 'react';
import DeleteBtn from './components/DeleteBtn';
import { Button, Table, Upload, message } from 'antd';
import { DeleteOutlined } from '@ant-design/icons';
import type { ActionType, ProColumns } from '@ant-design/pro-components';
import type { GradingFilingReportData, GradingFilingReportSelect } from '@/types/GradingFilingReport';
import { GradingFilingReportDataList, deleteDataById, GradingFilingReportUpload } from '@/service/GradingFilingReport'
import AddEditModal, { MODAL_TYPE } from './components/AddEditModal';
const GradingFilingReport = () => {
    const [columns, setColumns] = useState<ProColumns<GradingFilingReportData>[]>([]);
    const actionRef = useRef<ActionType>();
    const [SortOrderTest, setSortOrderTest] = useState<string>('');
    const [valueEnums, setValueEnums] = useState<GradingFilingReportSelect>({});
    // 获取表格数据
    const getData = async (filter: any) => {
        const params = { ...filter, offSet: filter.current, orderType: SortOrderTest };
        delete params.current;
        const { state, total, data } = (await GradingFilingReportDataList(params)) || {};
        if (state === 200) {
            return { data, success: true, total: total };
        } else {
            return { data: [] };
        }
    };
    // 下载文件
    const downLoadFileThis = async (item: any) => {
        let fileName = item.systemName + '.xlsx'
        let id = item.id
        let downloadParams = { id }
        let url = '/projectAcceptance/service/ratingFilingReportService/downloadReport/0'
        downLoad(url, downloadParams).then(res => {
            downLoadStream(res, fileName);
        }).catch((e) => {
            message.error('导出失败');
        }).finally(() => {
            console.log('完成');
        })
    }
    // 获取表格的表头数据
    const getTableConfig = async () => {
        const { columns, valueEnums } = await getTableColumns();
        setValueEnums(valueEnums);
        setColumns([
            ...columns,
            {
                title: '操作',
                valueType: 'option',
                key: 'option',
                fixed: 'right',
                width: 160,
                align: 'center',
                render: (text, record: any, index, action) => [
                    <AddEditModal
                        key={`edit_${record.id}`}
                        type={MODAL_TYPE.EDIT}
                        record={record}
                        valueEnums={valueEnums}
                        callback={() => {
                            action && action.reload();
                        }}
                    />,
                    <DeleteBtn<Array<any>>
                        key={`delete_${record.id}`}
                        params={record.id || ''}
                        method={deleteDataById}
                        callback={() => {
                            action && action.reload();
                        }}
                    />,
                    <Upload
                        key={`upload_${record.id}`}
                        showUploadList={false}
                        accept=".xlsx"
                        maxCount={1}
                        customRequest={({ file }) => {
                            const formData = new FormData();
                            formData.append('id', record.id);
                            formData.append('ins', file);
                            GradingFilingReportUpload(formData).then(res => {
                                if (res.state === 200) {
                                    message.success(res.message);
                                } else {
                                    message.error('上传失败');
                                }
                            })
                        }}
                    ><a >上传</a></Upload>
                    ,
                    <a key={`download_${record.id}`} onClick={() => downLoadFileThis(record)}>下载</a>
                ],
            },
        ]);
    }
    // 批量上传的方法
    const handleRequestAllFile = async (fileList: any[]) => {
        try {
            const formData = new FormData();
            fileList.forEach((file) => {
                formData.append('ins', file);
            })
            const res = await GradingFilingReportUpload(formData);
            if (res.state === 200) {
                message.success('文件上传成功');
            } else {
                message.error('文件上传失败');
            }
        } catch (e) {
            message.error('文件上传过程出错')
        }
    }
    // 批量上传的按钮
    const toolBarRender = (action: ActionType | undefined) => {
        return [
            <Upload
                showUploadList={false}
                multiple
                customRequest={({ file, onSuccess, onError }) => {
                    handleRequestAllFile([file]).then(() => onSuccess && onSuccess('上传成功')).catch(() => onError)
                }}
            >
                <a >批量上传</a>
            </Upload>
        ];
    };
    // 完成排序功能
    const handleChange = (pagination: any, filters: any, sorter: any) => {
        console.log(sorter, 'sorter');
        if (sorter.order !== undefined) {
            setSortOrderTest(sorter.order === 'descend' ? 'DESC' : 'ASC');
        }
    };
    // 初始化调用
    useEffect(() => {
        getTableConfig()
    }, [])
    return (
        <ProTable<GradingFilingReportData>
            rowKey="id"
            cardBordered
            actionRef={actionRef}
            request={getData}
            columns={columns}
            search={{
                labelWidth: 100,
            }}
            onChange={handleChange}
            toolBarRender={toolBarRender}
            scroll={{ x: 'max-content' }}
            rowSelection={{
                selections: [Table.SELECTION_ALL],
            }}
            tableAlertOptionRender={({ selectedRowKeys }) => {
                return (
                    <DeleteBtn<Array<any>>
                        content={
                            <Button type="link" icon={<DeleteOutlined />}>
                                {'批量删除'}
                            </Button>
                        }
                        method={deleteDataById}
                        params={selectedRowKeys}
                        callback={() => actionRef.current && actionRef.current.reload()}
                    />
                );
            }}
        />
    )
}
export default GradingFilingReport
相关推荐
蒙娜丽宁1 分钟前
Python在DevOps中的应用:自动化CI/CD管道的实现
开发语言·javascript·python
ihengshuai2 分钟前
手摸手实战前端项目CI CD
前端·ci/cd·云原生·kubernetes·devops
神舟之光34 分钟前
2025.1.16学习笔记(红宝书)
前端·笔记·学习
m0_748238632 小时前
2024最新版JavaScript逆向爬虫教程-------基础篇之Chrome开发者工具学习
javascript·chrome·爬虫
进击的企鹅呀5 小时前
h5使用video播放时关掉vant弹窗视频声音还在后台播放
前端·vue.js·音视频·html5
匹马夕阳6 小时前
基于vite+vue3+mapbox-gl从零搭建一个项目
前端·javascript·vue.js
木心操作6 小时前
js使用qrcode与canvas生成带logo的二维码
开发语言·javascript·ecmascript
松堂飞萤7 小时前
Web开发(二)CSS3基础与进阶
前端·css·css3
嵌入式郑工7 小时前
ssh,samba,tftp,nfs服务安装和配置
java·前端·ssh
创意锦囊7 小时前
服务端渲染(SSR)与客户端渲染(CSR)详解
前端