广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >AntDesignUpload文件上传功能的实现
  • 902
分享到

AntDesignUpload文件上传功能的实现

AntDesignUploadUpload文件上传功能AntDesignUpload文件上传 2023-05-17 08:05:37 902人浏览 八月长安
摘要

目录一、Ant Design Vue文件上传功能二、Ant Design React文件上传功能总结一、Ant Design Vue文件上传功能 1.文件上传选项框 <a-m

一、Ant Design Vue文件上传功能

1.文件上传选项框

 <a-modal
      title="上传文件"
      :footer="null"//不显示底部按钮
      :visible="visible"//是否显示
      :confirmLoading="confirmLoading"//确定按钮 loading
      @cancel="handleCancel"//取消方法
    >
      <a-upload
        :fileList="fileList"//上传的文件列表
        :remove="handleRemove"//文件删除方法
        :beforeUpload="beforeUpload"//上传文件之前的钩子,参数为上传的文件
      >
        <a-button>
          <a-icon type="upload" />选择文件
        </a-button>
      </a-upload>
    </a-modal>
<div class="streetAdd">
      <a-button type="primary" icon="plus" @click="engineeringadd()">新增</a-button>
      <a-button type="primary" icon="file" @click="showModal()">数据导入</a-button>
    </div>

效果:

在这里插入图片描述

在这里插入图片描述

2.js实现代码

//定义的变量
<script>
export default {
	data() {
	    return {
	      visible: false,
	      confirmLoading: false,
	      fileList: [],
	      IpConfig: this.IpConfig.projectServiceDomain,
	    }
	  },
	mounted: function () {
	    this.engineeringList()
	    //that.alarmTypes=res.data.res.dictionaryList;
	  },
	   methods: {
		   //点击数据导入按钮所调用的方法
		    showModal() {
		      this.visible = true
		    },
		    //对话框确认方法
		    handleOk(e) {
		      this.visible = false
		      this.confirmLoading = false
		    },
		    //关闭弹框
		    handleCancel(e) {
		      //console.log('Clicked cancel button')
		      this.visible = false
		    },
		    //删除上传文件
		    handleRemove(file) {
		      const index = this.fileList.indexOf(file)
		      const newFileList = this.fileList.slice()
		      newFileList.splice(index, 1)
		      this.fileList = newFileList
		    },
		    //显示上传文件内容
		    beforeUpload(file) {
		      this.spinning = true
		      var that = this
		      that.visible = false
		      //文件类型
		      var fileName = file.name.substring(file.name.lastIndexOf('.') + 1)
		      if (fileName != 'xlsx' && fileName != 'xls') {
		        this.$message.error('文件类型必须是xls或xlsx!')
		        this.spinning = false
		        that.visible = true
		        return false
		      }
		      //读取文件大小
		      var fileSize = file.size
		      //console.log(fileSize)
		      if (fileSize > 1048576) {
		        this.$message.error('文件大于1M!')
		        this.spinning = false
		        that.visible = true
		        return false
		      }
		      let fd = new FORMData()//表单格式
		      fd.append('file', file)//添加file表单数据
		      let url = this.IpConfig + '/xing/jtGongLuShouFeiZhan/upload'
		      this.$ajax({
		        method: 'post',
		        url: url,
		        data: fd,
		        headers: {
		          'Content-Type':
		            'multipart/form-data;boundary=' + new Date().getTime(),
		        },
		      })
		        .then((rsp) => {
		          console.log(rsp)
		          let resp = rsp.data
		          if (rsp.status == 200) {
		            that.fileList = []
		            that.visible = false
		            that.confirmLoading = false
		            that.$message.success('文件上传成功!')
		            this.spinning = false
		          } else {
		            this.$message.error('文件上传失败!')
		            that.visible = true
		          }
		        })
		        .catch((error) => {
		          this.$message.error('请求失败! error:' + error)
		          this.spinning = false
		          that.visible = true
		        })
		      return false
		    }
	    }
    }
</script>

二、Ant Design React文件上传功能

1.文件上传选项框

render() {
        const upLoad = {
            name: 'files',
            action: 'Http://192.168.0.102:7072/folder/annex/upload',//文件上传地址
            headers: {
                authorization: 'authorization-text',
            },
            onChange: this.handleChange.bind(this),//上传文件改变时的状态
            showUploadList: false,//是否展示文件列表
        }
        const { page, pages, fileType } = this.state;

        return (<React.Fragment>
        		<div className={styles.tableBtnBox}>
                            <Button disabled={this.state.showBtn} type="primary">新建</Button>
                            <Button 
	                            disabled={this.state.showBtn} //是否可用
	                            onClick={this.onUpload.bind(this)} //点击方法
	                            className={styles.uploadBtn} //样式
	                            type="primary"
	                            ghost
                             	>上传</Button>
                        </div>
                        
						<Modal
                            title="文件上传"
                            visible={this.state.uploadState}//是否显示
                            onOk={this.handleOk.bind(this)}//确认方法
                            onCancel={this.handleCancel.bind(this)}//取消方法
                        >
                            <Dragger {...upLoad}>
                                <p className="ant-upload-drag-icon">
                                    <InboxOutlined />
                                </p>
                                <p className="ant-upload-text">单击或拖动文件到此区域以上传</p>
                            </Dragger>,
                		</Modal>
                		
                </React.Fragment>)
      }

效果:

在这里插入图片描述

在这里插入图片描述

2. js实现代码


//点击上传按钮方法
   onUpload() {
           this.setState({
               uploadState: true,
           })
       }

   //文件上传
   handleChange(info) {
       var fileSize = info.file.size;
       if (info.file.status === 'done') {
           if (info.file.response.code === 500) {
               message.error('上传文件失败');
               return
           }
           let response = info.file.response.res[0];
           if (response.suffix == 'xlsx' || response.suffix == 'docx' || response.suffix == 'pdf') {//当文件类型是xlsx,docx,pdf三种格式时
               let userid = Number(localStorage.getItem('userid'));
               const baseUrl = 'http://192.168.0.123:8889';
               const api = '/zhyjxxzhpt/file/upload';
               let fd = new FormData();//表单格式
               fd.append("userid", userid);//添加userid数据
               fd.append("id", response.id);//添加id数据
               fd.append("name", response.name);//添加name数据
               fd.append("suffix", response.suffix);//添加suffix数据
               fd.append("type", response.type);//添加type数据
               axiOS({
                   url: baseUrl + api,//文件数据保存的地址
                   method: "post",
                   data: fd,
                   headers: {
                       "Content-Type": "multipart/form-data;boundary=" + new Date().getTime()
                   }
               }).then(res => {
                   if (res.data.code == 'success') {
                       message.success(`${response.name} 文件上传成功!`);
                   }

                   this.queryPrivate();

               })
           } else {
               message.error(`只能上传xlsx,docx,pdf文件!`);
               return false
           }

       } else if (info.file.status === 'error') {
           if (fileSize > 1048576) {
               message.error(`${info.file.name}文件大于1M!`);
           } else {
               message.error(`${info.file.name} 文件上传失败!`);
           }

       }
   }
//点击确定按钮方法
   handleOk = e => {
       this.setState({
           uploadState: false,
       });
   };
//取消方法
   handleCancel = e => {
       this.setState({
           uploadState: false,
       });
   };

总结

写在最后:

上述代码均是自己在开发过程中总结出来,或许还有不足之处,但是希望有些内容能够帮到大家,也希望大家多多支持编程网。

--结束END--

本文标题: AntDesignUpload文件上传功能的实现

本文链接: https://www.lsjlt.com/news/210849.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • AntDesignUpload文件上传功能的实现
    目录一、Ant Design Vue文件上传功能二、Ant Design React文件上传功能总结一、Ant Design Vue文件上传功能 1.文件上传选项框 <a-m...
    99+
    2023-05-17
    Ant Design Upload Upload文件上传功能 Ant Design Upload文件上传
  • Springboot文件上传功能的实现
    目录1.新建文件上传页面2.新建文件上传处理Controller类3.文件上传功能测试4.文件上传路径回显5.多文件上传功能实现6.文件名不同时的多文件上传处理1.新建文件上传页面 ...
    99+
    2023-05-15
    springboot文件上传 springboot文件上传方法
  • java实现文件的上传功能
    本文实例为大家分享了java实现文件的上传功能的具体代码,供大家参考,具体内容如下 直接上代码了 一、上传界面 <%@ page language="java" content...
    99+
    2022-11-13
  • springmvc实现文件上传功能
    一个简单的springmvc文件上传例子 所需的依赖 只需要这个就好了。在idea的依赖关系图中,commons-fileupload包含了commons-io依赖 <d...
    99+
    2022-11-11
  • ASP.NET实现文件上传功能
    本文实例为大家分享了ASP.NET实现文件上传功能的具体代码,供大家参考,具体内容如下 1、搭建网站结构 2、编写网页文件 创建一个Web窗体UploadFile和UpFile文件...
    99+
    2022-11-13
  • SpringBoot实现文件上传功能
    经典的文件上传 服务器处理上传文件一般都是先在请求中读取文件信息,然后改变名称保存在服务器的临时路径下,最后保存到服务器磁盘中。本次以thymeleaf搭建demo,因此需要引入th...
    99+
    2022-11-12
  • JSP实现文件上传功能
    本文实例为大家分享了JSP实现文件上传功能的具体代码,供大家参考,具体内容如下 一、准备部分 需要fileupload.jar与io.jar包共同完成。构建完成路径后可继续。 资源地...
    99+
    2022-11-12
  • javaweb实现文件上传功能
    本文实例为大家分享了javaweb实现文件上传的具体代码,供大家参考,具体内容如下 1、创建一个空项目 2、新建一个web application 的Module 3、创建一个lib...
    99+
    2022-11-13
  • JavaWeb实现上传文件功能
    本文实例为大家分享了JavaWeb实现上传文件的具体代码,供大家参考,具体内容如下 这是需要使用到的两个jar包一定要导入到lib目录中,并添加到发布的lib目录下 index.j...
    99+
    2022-11-13
  • ajaxfileupload.js实现上传文件功能
    下面是一个使用ajaxfileupload.js实现文件上传功能的示例代码:首先,你需要引入ajaxfileupload.js文件,...
    99+
    2023-08-11
    功能
  • Jeeplus-vue 实现文件的上传功能
    前端 一、uploadList.vue ① 首先在页面中添加一个放置图片的位置,来展示图片 <el-table-column prop="upload" labe...
    99+
    2022-11-13
  • Java实现多文件上传功能
    文件上传是开发中十分常见的功能,在servlet3.0之前,实现文件上传需要使用一些插件技术,比如: commons-fileupload smartupload ...
    99+
    2022-11-12
  • SpringBoot+Vue3实现上传文件功能
    目录前言一、后端二、前端三、演示前言 开发后台系统时经常遇到实现上传文件的功能,在这记录一下我的方法 后端:SpringBoot2前端:Vue3+ElementPlus工具:IDEA...
    99+
    2023-01-28
    vue3 springboot 文件上传 vue3 springboot 上传
  • jquery+springboot实现文件上传功能
    本文实例为大家分享了jquery+springboot实现文件上传功能的具体代码,供大家参考,具体内容如下 前端 <!DOCTYPE html> <html l...
    99+
    2022-11-12
  • javaweb实现文件上传小功能
    本文实例为大家分享了javaweb实现文件上传的具体代码,供大家参考,具体内容如下 1.创建文件上传页面 <%@ page contentType="text/html;cha...
    99+
    2022-11-13
  • Java+EasyExcel实现文件上传功能
    目录需求描述实现0、依赖1、编写配置类2、文件上传工具类3、编写Controller4、编写Service5、编写excel对应的类6、创建easyExcel的监听器7、最终效果需求...
    99+
    2023-02-24
    Java EasyExcel文件上传 Java EasyExcel上传 Java 文件上传 Java EasyExcel
  • WebUploader+SpringMVC实现文件上传功能
    WebUploader是由Baidu团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件。在现代的浏览器里面能充分发挥html5的优势,同时又不摒弃主流IE浏览器,沿用原来的FLASH运行时,兼容IE6+,iOS 6+, ...
    99+
    2023-05-31
    webuploader springmvc 文件上传
  • Struts2实现多文件上传功能
    前台form 表单:设置method=post,enctype=multipart/form-data。struts2在原有的上传解析器继承上做了进一步封装,更进一步简化了文件上传。Action需要使用3个属性来封装该文件域的信息:(1)类...
    99+
    2023-05-31
    struts2 上传 st
  • asp.net core webapi文件上传功能的实现
    最近开发一个新项目,使用了asp.net core 2.0,采用webapi开发后台,postgresql为数据库。最先来的问题就是上传文件的问题。 POST文件的一些坑 使用...
    99+
    2022-06-07
    net ASP.NET webapi core ASP
  • Android实现上传文件功能的方法
    本文所述为一个Android上传文件的源代码,每一步实现过程都备有详尽的注释,思路比较清楚,学习了本例所述上传文件代码之后,你可以应对其它格式文件的上传。实例中主要实现上传文件...
    99+
    2022-06-06
    方法 上传文件 Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作