vue Element Ui Upload 上传 点击一个按钮,选择多个文件后直接上传,使用防抖解决多次上传的问题。
问题:
在使用Element Ui Upload 上传文件时,选择多个文件上传时,on-change事件会一个一个返回上传的文件,导致前端不知道什么时候可以拿到全部上传的文件,再一起调后台接口。
解决方法:
上传文件后,自动把文件传给后台,这里做了一个防抖,等待500ms后在传给后台
代码实现:
<el-upload class="upload-demo" ref="enclosureUpload" accept=".docx" :file-list="fileList" action multiple :limit="7"
:show-file-list="false" :auto-upload="false" :on-change="handleFileChange"
:on-exceed="handleExceed" >
<el-button type="info" size="small" plain round >
上传
</el-button>
</el-upload>
// 文件超出个数限制时的钩子
handleExceed (files, fileList) {
this.$message.warning(`限制选择7个文件,本次选择了 ${files.length} 个文件`);
},
// 上传附件 过滤重复
filterRepetition (arr) {
let arr1 = []; //存id
let newArr = []; //存新数组
for (let i in arr) {
if (arr1.indexOf(arr[i].name) == -1) {
arr1.push(arr[i].name);
newArr.push(arr[i]);
}
}
return newArr;
},
// 修改 存放要上传的文件列表
handleFileChange (file, fileList) {
let arr = this.filterRepetition(fileList);
if (arr.length !== fileList.length) {
this.$message("上传重复文件,已过滤重复文件");
}
this.fileList = arr;
// 上传文件后,自动把文件传给后台,这里做了一个防抖,等待500ms后在传给后台
this.debounce(this.submitUpload, 500);
},
// element上传多个文件时,会把每个文件做个单独请求
// 这里的方法是请求最后一次
debounce (fn, waits) {
if (this.timer) {
clearTimeout(this.timer);
this.timer = null;
}
this.timer = setTimeout(() => {
fn.apply(this, arguments); // 把参数传进去
}, waits);
},
// 确定
async submitUpload () {
if (this.fileList.length === 0) {
this.$message.success("请上传文件");
return;
}
let formData = new FormData(); // 用FormData存放上传文件
this.fileList.forEach((file) => {
formData.append("file", file.raw);
});
// 确定上传 把在上传列表里的文件 合并到formData里面传给后台
let res = await importXlsx(formData);
this.fileList = []
this.$message.success('上传成功')
}
相关文章:
vue Element Ui Upload 上传 点击一个按钮,选择多个文件后直接上传,使用防抖解决多次上传的问题。
问题: 在使用Element Ui Upload 上传文件时,选择多个文件上传时,on-change事件会一个一个返回上传的文件,导致前端不知道什么时候可以拿到全部上传的文件,再一起调后台接口。 解决方法: 上传文件后&…...
【HF设计模式】05-单例模式
声明:仅为个人学习总结,还请批判性查看,如有不同观点,欢迎交流。 摘要 《Head First设计模式》第5章笔记:结合示例应用和代码,介绍单例模式,包括遇到的问题、采用的解决方案、以及达到的效果。…...
运维人员的Python详细学习路线
以下是一条适合运维人员的Python详细学习路线: 一、基础入门阶段(第1 - 2个月) 环境搭建与基础语法(第1个月) 安装与配置 在运维常用的操作系统(如Linux或Windows)上安装Python。对于Linux系统…...
软件体系结构与设计模式
在软件开发中,软件体系结构和设计模式是两个至关重要的概念。它们帮助开发者设计出易于理解、可扩展、可维护的系统。尽管这两个概念密切相关,但它们分别关注系统的不同方面:软件体系结构关注的是系统整体结构的设计,而设计模式则…...
安徽省地图arcgis数据美化后mxd文件shp格式下载后内容测评
标题中的“安徽省地图arcgis数据美化后mxd文件shp格式”揭示了这个压缩包的内容是经过GIS处理的、针对安徽省地图数据。ArcGIS是一款由Esri公司开发的专业地理信息系统软件,用于处理、分析和展示地理空间数据。MXD文件是ArcGIS的项目文件,包含了地图布局…...
MySQL数据库备份与恢复策略
数据是企业和应用的核心资产,可靠的备份和恢复策略是确保数据安全性和业务连续性的关键。在本篇文章中,我们将详细介绍 MySQL 数据库的备份和恢复方法,包括逻辑备份、物理备份、自动化备份,以及常见问题的处理方法。 一、逻辑备份 逻辑备份是通过导出数据库的结构和数据生…...
go语言zero框架中教务crm系统的在职继承和离职交接的设计与实践
在GoZero中实现一个在职继承和离职交接的通用模块,涉及到顾问离职交接客户、领导离职交接审批单据等功能。为了使这个模块通用且易于扩展,我们可以分成几个部分: 1. **数据模型设计**:我们首先需要设计离职交接相关的数据模型。 …...
C# 设计模式(结构型模式):桥接模式
C# 设计模式(结构型模式):桥接模式 在软件设计中,我们经常会遇到系统的变化频繁,或者需要灵活扩展功能的场景。这时,桥接模式(Bridge Pattern)便显得尤为重要。桥接模式是一个结构型…...
C# 设计模式(行为型模式):解释器模式
C# 设计模式(行为型模式):解释器模式 (Interpreter Pattern) 什么是解释器模式? 解释器模式(Interpreter Pattern)是一种行为型设计模式,用于定义一种语言的语法表示,并提供一个解释…...
如何 cURL Elasticsearch:进入 Shell
作者:来自 Elastic Philipp Krenn Kibana 的控制台是开始使用 Elasticsearch 的 REST API 的最简单方法 - 语法突出显示、自动完成、格式化、导出 cURL、JavaScript 或 Python。而且你不必担心正确的端点、身份验证等。但是有时,如果 Kibana 不可用、你…...
深信服云桌面系统的终端安全准入设置
深信服的云桌面系统在默认状态下没有终端的安全准入设置,这也意味着同样的虚拟机,使用云桌面终端或者桌面套件都可以登录,但这也给系统带来了一些安全隐患,所以,一般情况下需要设置终端的安全准入策略,防止…...
Node.js 模块系统
Node.js 模块系统 1. 引言 Node.js,作为一个轻量级、高效的服务器端 JavaScript 运行环境,其模块系统是其最核心的特性之一。Node.js 的模块系统允许开发者将代码组织成多个文件,每个文件都是一个模块,这样可以提高代码的可维护性和可重用性。本文将详细介绍 Node.js 的模…...
数据结构知识收集尊享版(迅速了解回顾相关知识)
1、单链表、循环链表、双向链表,存储、逻辑结构 单链表、循环链表和双向链表都是线性表的链式存储结构,它们在存储和逻辑结构上有一些共同点和不同点。 存储结构 单链表:每个节点包含一个数据域和一个指针域,指针域指向下一个节…...
SpringMVC启动与请求处理流程解析
目录 SpringMVC的基本结构 1.MVC简介 2.基本结构 什么是Handler? 什么是HandlerMapping? 什么是HandlerAdapter? RequestMapping方法参数解析 DispatcherServlet的init()方法 DispatcherServlet的doService()方法 SpringBoot整合SpringMVC …...
C++ 日志库 spdlog 使用教程
Spdlog是一个快速、异步、线程安全的C日志库,他可以方便地记录应用程序的运行状态,并提供多种输出格式。官网:https://github.com/gabime/spdlog 安装教程可以参考:https://blog.csdn.net/Harrytsz/article/details/144887297 S…...
`http_port_t
http_port_t 是 SELinux(Security-Enhanced Linux)中的一种端口类型标签,用于标识哪些端口可以被 HTTP 和 HTTPS 服务使用。SELinux 是一种强制访问控制(MAC)安全模块,它通过定义安全策略来限制进程对系统资…...
SpringBoot中实现拦截器和过滤器
【SpringBoot中实现过滤器和拦截器】 1.过滤器和拦截器简述 过滤器Filter和拦截器Interceptor,在功能方面很类似,但在具体实现方面差距还是比较大的。 2.过滤器的配置 2.1 自定义过滤器,实现Filter接口(SpringBoot 3.0 开始,jak…...
不锈钢均温板结合强力粘合技术革新手机内部架构
摘要: 本文介绍了一种创新性的手机内部架构设计方案,其中不锈钢均温板不仅作为高效的散热元件,还充当了手机中框的主要结构件。通过使用强力不可拆胶水将主板、尾插和其他关键部件直接粘合到均温板上,该方案实现了更为紧密的热耦合…...
Docker安装使用
文章目录 Docker安装Docker的基础使用搜索&拉取镜像 Docker的生命周期利用Docker切换不同OSDocker容器 镜像的保存&分享Docker存储Docker网络 Docker安装 更新apt索引 sudo apt-get update添加Docker所需要的依赖 apt-get install ca-certificates curl gnupg lsb-r…...
React 如何进行路由变化监听
一、使用react-router库(以react-router-dom为例) 1. 历史(history)对象监听 1.1 原理 react-router内部使用history对象来管理路由历史记录。可以通过访问history对象来监听路由变化。在基于类的组件中,可以通过组…...
Qwen-Image-2512-SDNQ功能体验:负面提示词、宽高比调节等高级选项实测
Qwen-Image-2512-SDNQ功能体验:负面提示词、宽高比调节等高级选项实测 1. 开篇:当AI绘画遇上专业级控制 在AI绘画工具泛滥的今天,真正能让创作者感到"趁手"的解决方案却不多见。大多数工具要么功能过于简单,要么参数复…...
AI搜索排名怎么查?2026免费GEO监测手把手教你精准监控品牌AI可见性
一家工业设备制造商的市场总监最近很困惑:他们的官网在百度搜索“高精度传感器”这个关键词上排名前三,SEO团队为此自豪。但当客户用豆包、DeepSeek提问“哪个品牌的传感器精度最高”时,AI的答案里却完全没有他们的影子。客户流失了ÿ…...
3分钟搞定!免费解锁AMD/Intel处理器性能的终极指南
3分钟搞定!免费解锁AMD/Intel处理器性能的终极指南 【免费下载链接】Universal-x86-Tuning-Utility Unlock the full potential of your Intel/AMD based device. 项目地址: https://gitcode.com/gh_mirrors/un/Universal-x86-Tuning-Utility 还在为电脑性能…...
打造你的私人游戏云:Sunshine串流服务器从零到精通
打造你的私人游戏云:Sunshine串流服务器从零到精通 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine 还在为游戏设备限制而烦恼吗?想在任何地方都能畅玩你的P…...
网络协议:BFD
文章目录 BFD RFC 7419 开源软件 omni switch vpp keepalived openswitch BFD 自从我接手一个网络项目,从2018年开始做BFD,一直到2026年,还没有完成,现在看项目计划BFD的开发都要拖到2028年了。一个主要的原因是需求没有这么强烈,原来的网络检测方法以及够用,满足需求。…...
2026年AI发展实录:从医疗场景突破到全行业落地,技术人必看的趋势与启示
前言:AI的发展早已告别“概念炒作”,迈入“实干落地”的深水区。尤其是2026年以来,政策引导、技术迭代与行业需求三者同频共振,让AI从“实验室技术”真正走进千行百业,其中医疗领域的突破最为直观,也为其他…...
UniApp里用web-view预览PDF?小心这些性能坑和体验优化点
UniApp中WebView加载PDF的深度优化指南:从性能瓶颈到极致体验 在移动应用开发领域,PDF预览功能几乎是企业级应用的标配需求。UniApp作为跨平台开发框架,通过WebView实现PDF预览看似简单直接,但当项目进入生产环境,特别…...
AIAgent能支撑AGI吗?SITS2026圆桌激辩实录:8大底层能力缺口与2026年前必须攻克的3座技术高峰
第一章:SITS2026圆桌:AIAgent与AGI的关系 2026奇点智能技术大会(https://ml-summit.org) AIAgent 与 AGI 并非线性演进关系,而是认知架构、目标建模与自主演化能力的质变交界。在 SITS2026 圆桌讨论中,多位前沿研究者指出&#…...
三行代码背后的宇宙:当美军封锁霍尔木兹海峡,你的系统能扛住吗?
"The chain is only as strong as its weakest link." - Thomas Reid什么是短链接?这道题的完整解法短链接(URL Shortener)把一个很长的网址变成一个简短的链接,用户点击短链接,系统自动跳转到原始地址。核心…...
SolidWorks三维设计上云指南:制造企业如何用1台云主机实现10人高效协同?
随着云计算技术的成熟,SolidWorks云主机凭借其显著优势,为制造企业提供了全新的解决方案。通过将SolidWorks部署至云端,企业可突破本地硬件限制,实现“一台云主机支持多人协同设计”的轻量化运营模式。这一模式不仅降低了IT投入与…...
