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>
相关推荐
幼儿园技术家31 分钟前
多方案统一认证体系对比
前端
十一.36637 分钟前
83-84 包装类,字符串的方法
前端·javascript·vue.js
over6971 小时前
深入解析:基于 Vue 3 与 DeepSeek API 构建流式大模型聊天应用的完整实现
前端·javascript·面试
用户4099322502121 小时前
Vue3计算属性如何通过缓存特性优化表单验证与数据过滤?
前端·ai编程·trae
接着奏乐接着舞1 小时前
react useMeno useCallback
前端·javascript·react.js
码农阿豪1 小时前
Vue项目构建中ESLint的“换行符战争”:从报错到优雅解决
前端·javascript·vue.js
xhxxx2 小时前
AI打字机的秘密:一个 buffer 如何让机器学会“慢慢说话”
前端·vue.js·openai
韩曙亮2 小时前
【Web APIs】BOM 浏览器对象模型 ⑥ ( location 对象 | location 常用属性和方法 | URL 简介 )
前端·javascript·dom·url·bom·location·浏览器对象模型
用户21411832636022 小时前
CC-Switch配置切换神器:5秒搞定多设备同步,坚果云让配置永不丢失
前端
勤奋的懒洋洋3502 小时前
前端实现多个图片打包下载
前端