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>
相关推荐
火星牛16 分钟前
AI IDE试用(一)
javascript·ide
jump_jump3 小时前
基于 Squoosh WASM 的浏览器端图片转换库
前端·javascript·性能优化
小二·6 小时前
前端监控体系完全指南:从错误捕获到用户行为分析(Vue 3 + Sentry + Web Vitals)
前端·vue.js·sentry
阿珊和她的猫7 小时前
IIFE:JavaScript 中的立即调用函数表达式
开发语言·javascript·状态模式
阿珊和她的猫7 小时前
`require` 与 `import` 的区别剖析
前端·webpack
智商偏低7 小时前
JSEncrypt
javascript
谎言西西里7 小时前
零基础 Coze + 前端 Vue3 边玩边开发:宠物冰球运动员生成器
前端·coze
努力的小郑8 小时前
2025年度总结:当我在 Cursor 里敲下 Tab 的那一刻,我知道时代变了
前端·后端·ai编程
GIS之路8 小时前
GDAL 实现数据空间查询
前端
OEC小胖胖8 小时前
01|从 Monorepo 到发布产物:React 仓库全景与构建链路
前端·react.js·前端框架