Antd的Upload上传组件的使用方式

Antd的Upload上传组件

1.上传图片

在这里插入图片描述

// 上传获取fileId并下载file
  const customRequest = async (options) => {
    const { file, onProgress, onError, onSuccess } = options
    setLoading(true)
    const formData = new FormData();
    formData.append('file', picFile);
    formData.append('folderName','bzf-portal-background');
    formData.append('project',"bzf-portal-background");
    const { data, code } = await api.upLoadFileRecord(formData);
    if (code == 1) {
      const fileId = data;
      setPicid(data);
      const res = await api.downloadFileAddressRecord({ fileId });
      if (res.code == 1) {
        setImageUrl(res.data);
        //刚开始写好后发现文件已经上传成功,但是没有上传进度,一直显示文件正在上传中,就加上了以下代码
        onProgress({ percent: 100 })
        onSuccess(res, file);
        // console.log('file是什么',file);
        file.status = 'done'
        message.success('文件上传成功');
        // console.log(res.data, '结果');
      }
    } else {
      if (editpic) {
        const res = await api.downloadFileAddressRecord({
          fileId: editpic,
        });
        if (res.code == 1) {
          setImageUrl(res.data);
        }
      }
    }
  }
  
  //上传文件前的钩子
 const beforeUpload = (file) => {
    console.log(file, '文件');
    const isJpgOrPng = file.type === 'image/jpeg' || file.type === 'image/png';
    if (!isJpgOrPng) {
      message.error('只能上传JPG/PNG格式文件!');
      return false;
    }
    const isLt10M = file.size / 1024 / 1024 < 10;
    if (!isLt10M) {
      message.error('图片大小不能超过10MB!');
      return false;
    }
    setFile(file);
  }; 

// Upload组件
<Upload 
  action="/api/bzf-business-file/fileManage/uploadFileWithRename" //上传文件的接口地址
  listType="picture-card" 
  data={{folderName:"bzf-portal-background",project:"bzf-portal-background"}}//请求参数
  customRequest={customRequest}
  showUploadList={true}
  beforeUpload={(file)=>{beforeUpload(file)}}
  // onChange={handleChange}
  maxCount={1}
  > 
  {isEdit ? (
      <div>
        {/* {console.log('imageUrl',imageUrl)} */}
      <img
        src={imageUrl}
        style={{
          width: '90px',
          height: '90px',
        }}
      />
      </div>
    ) : (
    <div>
      <PlusOutlined />
      <div style={{ marginTop: 8 }}>Upload</div>
    </div>)}
 </Upload>

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 antd 组件 Upload上传文件给后端,你需要进行以下步骤: 1. 安装 antd 组件库: ``` npm install antd ``` 2. 在你的代码中引入所需的组件: ```jsx import { Upload, Button } from 'antd'; import { UploadOutlined } from '@ant-design/icons'; ``` 3. 创建一个状态来存储上传文件的列表: ```jsx const [fileList, setFileList] = useState([]); ``` 4. 创建一个函数来处理文件上传: ```jsx const handleUpload = () => { const formData = new FormData(); fileList.forEach(file => { formData.append('files', file); }); // 发送上传请求给后端 // 使用 axios 或其他 HTTP 库发送 POST 请求 // 例如: // axios.post('/api/upload', formData) // .then(response => { // // 处理上传成功后的逻辑 // }) // .catch(error => { // // 处理上传失败后的逻辑 // }); }; ``` 5. 在渲染的 JSX 中使用 Upload 组件: ```jsx <Upload fileList={fileList} onChange={({ fileList }) => setFileList(fileList)} > <Button icon={<UploadOutlined />}>选择文件</Button> </Upload> <Button onClick={handleUpload}>上传</Button> ``` 上述代码中,我们使用antdUpload 组件来创建一个文件上传的区域。通过设置 fileList 属性和 onChange 事件来管理上传的文件列表。当用户选择文件后,fileList 状态会自动更新。 最后,我们创建了一个按钮来触发 handleUpload 函数,该函数会将文件列表中的文件转换为 FormData,并发送 POST 请求给后端进行文件上传。 请注意,此处的上传逻辑仅为示例,具体的后端处理逻辑需要根据你的后端框架来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值