react中,使用antd的Upload组件上传zip压缩包文件

需求

使用antd的Upload上传.zip压缩包文件

代码

javascript 复制代码
const [uploadLoaing, setUploadLoaing] = useState(false);

// 辅助函数:检查文件是否为zip格式
  function isZipFile(file: File): boolean {
    const fileType = file.type;
    return fileType === 'application/zip' || file.name.endsWith('.zip');
  }

const props= {
    name: 'file',
    multiple: false,
    action: `${envConfig.baseURL}/model/import`,   //上传的接口地址
    headers: {
      'X-Webtoken': getToken() || '',   //请求头携带token
    },
    accept: '.zip',
    showUploadList: false,
    onChange(info) {
      console.log('info=>', info);
      const { status } = info.file;
      if (status === 'uploading') {
        setUploadLoaing(true);
      }
      if (status === 'done') {
        if (info.file.response.code === 0) {
          message.success(`文件导入成功`);
          setUploadLoaing(false);
        } else {
          const errorMsg = info.file.response.data?.[0] || info.file.response.desc || '文件导入失败';
          message.error(errorMsg);
          setUploadLoaing(false);
        }
      } else if (status === 'error') {
        message.error(`文件导入失败`);
        setUploadLoaing(false);
      }
    },

    beforeUpload(file) {
      const isZip = isZipFile(file);
      const maxSize = 200 * 1024 * 1024;
      if (!isZip) {
        message.error('请上传一个压缩包文件。');
      } else if (file.size > maxSize) {
        message.error('文件大小不能超过200兆。');
      }

      return isZip && file.size <= maxSize;   //若返回false,则阻止上传行为
    },
};


<Upload {...props}>
    <Button loading={uploadLoaing}>上传</Button>
</Upload>
相关推荐
用户9481817675442 分钟前
超越NAT:如何构建高效、安全的内网穿透隧道
前端
明天的明6 分钟前
vue双向数据绑定失效
前端
bug_kada8 分钟前
前端路由:深入理解History模式
前端·面试
bug_kada10 分钟前
前端路由:Hash vs History,一篇讲明白!
前端·面试
李明卫杭州13 分钟前
CSS 中 nth-child 选择器的详细用法和示例
前端
会豪13 分钟前
CSS 动画属性精讲:从基础到实战
前端·css
Ticnix19 分钟前
vue的draggable拖拽属性+Echarts实现可视化自定义数据看板
前端
XTransfer技术20 分钟前
RN也有微前端框架了? Xtransfer的RN优化实践(一)多bundle架构
前端·react native
Mintopia20 分钟前
Next 全栈之 API 测试:Supertest 与 MSW 双雄记 🥷⚔️
前端·javascript·next.js
泽泽爱旅行21 分钟前
awk 语法解析-前端学习
linux·前端