Ant Design/Reactjs上传器(拖拽上传)停止上传列表加载。
创始人
2024-11-07 05:31:30
0

以下是一个使用Ant Design和Reactjs的示例代码,演示了如何实现拖拽上传并停止上传列表加载的功能:

import React, { useState } from 'react';
import { Upload, Button, Icon, message } from 'antd';

const Dragger = Upload.Dragger;

const UploadComponent = () => {
  const [fileList, setFileList] = useState([]);
  const [uploading, setUploading] = useState(false);
  const [stopUploading, setStopUploading] = useState(false);

  const handleUpload = () => {
    const formData = new FormData();
    fileList.forEach(file => {
      formData.append('files', file);
    });

    // 发起上传请求
    // 这里可以使用axios或其他HTTP库发送请求
    // 根据需要处理上传进度等其他逻辑
    // 此处只是简单的演示
    setUploading(true);
    setTimeout(() => {
      if (stopUploading) {
        message.error('上传已停止');
        setUploading(false);
        setStopUploading(false);
        setFileList([]);
      } else {
        message.success('上传成功');
        setUploading(false);
        setFileList([]);
      }
    }, 2000);
  };

  const handleRemove = file => {
    setFileList(fileList.filter(item => item.uid !== file.uid));
  };

  const handleStopUpload = () => {
    setStopUploading(true);
  };

  const uploadProps = {
    multiple: true,
    fileList,
    beforeUpload: file => {
      setFileList([...fileList, file]);
      return false;
    },
    onRemove: handleRemove,
  };

  return (
    

点击或拖拽文件到此区域进行上传

{uploading && ( )}
); }; export default UploadComponent;

上述代码创建了一个名为UploadComponent的组件,其中包含一个Dragger组件用于实现拖拽上传功能。fileList存储上传的文件列表,uploading表示当前是否正在上传,stopUploading表示是否停止上传。

handleUpload函数中,使用formData将文件列表添加到表单数据中,然后可以使用HTTP库发送上传请求。在示例中,使用setTimeout模拟上传过程,并根据stopUploading的值来模拟停止上传。

handleRemove函数用于移除文件列表中的文件。

uploadProps是传递给Dragger组件的属性对象,其中包含beforeUploadonRemove等属性,用于处理文件的添加和移除。

在界面上,用户可以点击或拖拽文件到Dragger组件区域进行上传。点击"开始上传"按钮后,会调用handleUpload函数开始上传。如果点击"停止上传"按钮,则会调用handleStopUpload函数停止上传。

需要注意的是,上述代码只是一个简单的示例,实际使用中,可能需要根据需求进行适当的修改和完善。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...