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>
相关推荐
ネф̶-イω2 小时前
登录、注册、忘记密码、首页HTML模板
前端·css·html
小殷要努力刷题!2 小时前
JavaWeb项目——如何处理管理员登录和退出——笔记
java·javascript·笔记·学习·servlet·javaweb·寒假
小李老笨了3 小时前
React的渲染流程
javascript·react.js·ecmascript
冰淇淋百宝箱3 小时前
GraphRAG: Auto Prompt Tuning 实践
java·服务器·前端
记得开心一点嘛4 小时前
uniapp --- 配置文件
前端·typescript·uni-app
Bingo_BIG4 小时前
uni-app main.js中全局变量的使用
javascript·vue.js·uni-app
Bingo_BIG4 小时前
uni-app vue3 常用页面 组合式api方式
前端·javascript·uni-app
无限大.4 小时前
基于 HTML5 Canvas 制作一个精美的 2048 小游戏--day2
前端·html·html5
索然无味io5 小时前
PHP基础--流程控制
前端·笔记·后端·学习·web安全·网络安全·php