当前位置: 首页 > news >正文

vue2,使用element中的Upload 上传文件,自定义上传http-request上传,上传附件支持多选,多个文件只发送一次请求,代码里有注释

复制直接使用,组件根据multiple是否多选来返回附件内容,支持多选就返回数据附件,则返回一个附件对象。

//uploadFiles.vue<template><div><el-uploadclass="avatar-uploader"action="#":accept="accept":show-file-list="false":http-request="HttpRequest":multiple="multiple":on-change="onChangeFile"ref="uploadFileRef"><slot /></el-upload></div>
</template><script>
export default {/*** limitation // 文件上传限制大小 type number  50就是50Mb* accept // 上传文件类型限制 accept=".xls, .xlsx"* multiple// 是否支持多选*/name: "uploadFiles",props: ['limitation','accept','multiple'],data() {return {flag:true, // 节流控制filesList:[]  // 上传的附件内容}},methods: {// 触发父组件的fileRet方法,并返回所选附件数据ArrayupdateHeading(files) {this.$emit('fileRet',files);this.emptyData();},HttpRequest(data){const isLt50M = data.file.size / 1024 / 1024 < this.limitation; // 限制文件大小if (!isLt50M) {this.$message.error('上传头像图片大小不能超过 50MB!');return}// 调用后台接口逻辑this.throttle(()=>{let retFile;// 如何支持多文件上传,返回附件数组,则返回当个文件对象if (this.multiple){retFile = this.filesList.map(o=>o.raw)} else {retFile = data.file}// 附件上传参数用formData.append('file',retFile)  this.updateHeading(retFile)},600)},// 清空已上传的附件数据,初始化emptyData() {this.$refs.uploadFileRef && this.$refs.uploadFileRef.clearFiles();this.filesList = [];},//使用节流的方式去触发提交,避免多上传附件时,选几个附件就会触发几次提交throttle(fn,delay){if(this.flag){setTimeout(() =>{ fn();this.flag = true },delay)}this.flag = false;},onChangeFile(file,fileList){this.filesList = fileList},},mounted() {},computed: {},watch: {}
}
</script>

http://www.lryc.cn/news/134440.html

相关文章:

  • flutter定位简单工具类
  • java请求SAP系统,发起soap的xml报文,实体类转换,idea自动生成教程
  • 不同屏幕的触控技术
  • 深度解读thenable
  • 原生无限极目录树详细讲解
  • 剑指offer(C++)-JZ64:求1+2+3+...+n(算法-位运算)
  • “深入探究JVM内部机制:如何实现Java程序的运行环境?“
  • Mac更新homebrew时卡住的解决办法
  • 带你了解—在外远程群晖NAS-群晖Drive挂载电脑磁盘同步备份【无需公网IP】
  • 计算机网络第2章(物理层)
  • windows钩子保护自身进程不被破坏
  • Linux系统查看文件系统类型C代码
  • Python中的正则表达式
  • 第六章,创作文章
  • Win10c盘满了怎么清理?快速清理,5个方法!
  • 回归预测 | MATLAB实现GWO-BP灰狼算法优化BP神经网络多输入单输出回归预测(多指标,多图)
  • docker 06(docker compose)
  • 非阻塞重试与 Spring Kafka 的集成测试
  • 基于 Debian 12 的MX Linux 23 正式发布!
  • Nginx代理功能与负载均衡详解
  • 部署问题集合(特辑)虚拟机常用命令
  • 【Git】如何将本地文件进行Git仓库归档
  • uniapp 使用腾讯视频 的 坑
  • LinkedList
  • 创作新纪元:知乎、阅文加码AI大模型,撬动创作者经济
  • PAT(Advanced Level) Practice(with python)——1067 Sort with Swap(0, i)
  • Python爬取斗罗大陆全集
  • 前馈神经网络解密:深入理解人工智能的基石
  • 顺序栈Sequential-stack
  • 关于工牌(必须5-10个字)