antd Upload组件上传状态一直处于uploading

antd Upload组件上传状态一直处于uploading

对于受控模式,需要在 onChange 中始终 setState fileList,保证所有状态同步到 Upload 内

import { UploadFile, UploadProps } from 'antd/es/upload/interface';

...

const [fileList, setFileList] = useState<UploadFile[]>([]);

const uploadProps: UploadProps = {
    accept: '*',
    maxCount: 1,
    action: 'url',
    onChange(info: any) {
      if (info.file.status === 'done') {
        if (info.file.response.code === 201) {
          //form.setFieldsValue({ filePath: info.file.response.data.fullPath });
          console.log(info.file.name);
          setFileList(info.fileList);
          notification.success({ key: 'success', message: `上传成功!` });
        } else {
          notification.error({ key: 'error', message: `${info.file.name} 上传失败!` });
        }
      }
      if (info.file.status === 'error') {
        notification.error({ key: 'error', message: `${info.file.name} 上传失败!` });
      }
      //每次onChange都需要更新fileList
      setFileList(info.fileList);
    },
    fileList: fileList,
  };
}

const normFile = (e: any) => {
  if (Array.isArray(e)) {
    return e;
  }
  if (e.file.status === 'done') {
    return e.file.response.data.fullPath;
  }
  return e && e.fileList;
};
...

<Form.Item
    label="文件"
    name="filePath"
    valuePropName="file"
    getValueFromEvent={normFile}
  >
    <>
      <Upload
        name="file"
        {...uploadProps}
      >
        <Button icon={<UploadOutlined />}>上传文件</Button>
      </Upload>
    </>
</Form.Item>


  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您可以按照以下步骤来实现antd upload上传图片: 1. 首先安装antd和axios。 ```bash npm install antd axios --save ``` 2. 在您的组件中引入antd upload组件。 ```javascript import { Upload, message } from 'antd'; import { LoadingOutlined, PlusOutlined } from '@ant-design/icons'; class UploadImage extends React.Component { state = { loading: false, imageUrl: '', }; handleChange = info => { if (info.file.status === 'uploading') { this.setState({ loading: true }); return; } if (info.file.status === 'done') { // Get this url from response in real world. getBase64(info.file.originFileObj, imageUrl => this.setState({ imageUrl, loading: false, }), ); } }; render() { const { loading, imageUrl } = this.state; const uploadButton = ( <div> {loading ? <LoadingOutlined /> : <PlusOutlined />} <div style={{ marginTop: 8 }}>Upload</div> </div> ); return ( <Upload name="avatar" listType="picture-card" className="avatar-uploader" showUploadList={false} action="https://www.mocky.io/v2/5cc8019d300000980a055e76" beforeUpload={beforeUpload} onChange={this.handleChange} > {imageUrl ? <img src={imageUrl} alt="avatar" style={{ width: '100%' }} /> : uploadButton} </Upload> ); } } ``` 3. 在handleChange方法中,您需要将上传的图片转换为base64格式,以便于后续的保存和显示。 ```javascript import { Upload, message } from 'antd'; import { LoadingOutlined, PlusOutlined } from '@ant-design/icons'; function getBase64(file) { return new Promise((resolve, reject) => { const reader = new FileReader(); reader.readAsDataURL(file); reader.onload = () => resolve(reader.result); reader.onerror = error => reject(error); }); } class UploadImage extends React.Component { state = { loading: false, imageUrl: '', }; handleChange = info => { if (info.file.status === 'uploading') { this.setState({ loading: true }); return; } if (info.file.status === 'done') { // Get this url from response in real world. getBase64(info.file.originFileObj, imageUrl => this.setState({ imageUrl, loading: false, }), ); } }; render() { const { loading, imageUrl } = this.state; const uploadButton = ( <div> {loading ? <LoadingOutlined /> : <PlusOutlined />} <div style={{ marginTop: 8 }}>Upload</div> </div> ); return ( <Upload name="avatar" listType="picture-card" className="avatar-uploader" showUploadList={false} action="https://www.mocky.io/v2/5cc8019d300000980a055e76" beforeUpload={beforeUpload} onChange={this.handleChange} > {imageUrl ? <img src={imageUrl} alt="avatar" style={{ width: '100%' }} /> : uploadButton} </Upload> ); } } ``` 4. 最后,在handleSubmit方法中,您可以将base64格式的图片传给后端进行保存。 ```javascript import { Upload, message } from 'antd'; import { LoadingOutlined, PlusOutlined } from '@ant-design/icons'; import axios from 'axios'; function getBase64(file) { return new Promise((resolve, reject) => { const reader = new FileReader(); reader.readAsDataURL(file); reader.onload = () => resolve(reader.result); reader.onerror = error => reject(error); }); } class UploadImage extends React.Component { state = { loading: false, imageUrl: '', }; handleChange = info => { if (info.file.status === 'uploading') { this.setState({ loading: true }); return; } if (info.file.status === 'done') { // Get this url from response in real world. getBase64(info.file.originFileObj, imageUrl => this.setState({ imageUrl, loading: false, }), ); } }; handleSubmit = () => { axios.post('/api/upload', { image: this.state.imageUrl, }).then(response => { message.success('Image uploaded successfully!'); }).catch(error => { message.error('Failed to upload image!'); }); }; render() { const { loading, imageUrl } = this.state; const uploadButton = ( <div> {loading ? <LoadingOutlined /> : <PlusOutlined />} <div style={{ marginTop: 8 }}>Upload</div> </div> ); return ( <div> <Upload name="avatar" listType="picture-card" className="avatar-uploader" showUploadList={false} action="https://www.mocky.io/v2/5cc8019d300000980a055e76" beforeUpload={beforeUpload} onChange={this.handleChange} > {imageUrl ? <img src={imageUrl} alt="avatar" style={{ width: '100%' }} /> : uploadButton} </Upload> <Button type="primary" onClick={this.handleSubmit}>Submit</Button> </div> ); } } ``` 以上就是antd upload上传图片的实现步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值