vxe-upload vue 实现附件上传、手动批量上传附件的方式

查看官网:https://vxeui.com

安装

npm install vxe-pc-ui@4.6.47
// ...
import VxeUIAll from 'vxe-pc-ui'
import 'vxe-pc-ui/lib/style.css'
// ...createApp(App).use(VxeUIAll).mount('#app')
// ...

上传附件支持失败重新上传

自定义重新上传,通过参数 show-error-status 启用,当上传失败时,可以点击重新上传按钮

在这里插入图片描述

<template><div><vxe-upload v-model="fileList" multiple :limit-count="6" :limit-size="50" show-progress show-error-status auto-hidden-button :upload-method="uploadMethod"></vxe-upload></div>
</template><script setup>
import { ref } from 'vue'
import axios from 'axios'const fileList = ref([])// 后端接口模拟请求失败
const uploadMethod = ({ file, updateProgress }) => {const formData = new FormData()formData.append('file', file)return axios.post('/api/pub/upload/single?randomError=1', formData, {onUploadProgress (progressEvent) {const percentCompleted = Math.round((progressEvent.loaded * 100) / (progressEvent.total || 0))updateProgress(percentCompleted)}}).then((res) => {return {...res.data}})
}
</script>

上传附件、手动批量上传

当需要手动批量提交上传时,可以通过 aotu-submit=false 关闭自动提交,然后手动调用 submit() 方法提交

在这里插入图片描述

<template><div><vxe-button status="primary" @click="submitEvent">点击手动上传</vxe-button><vxe-uploadmultipleshow-progressv-model="fileList"ref="refUpload"button-text="选择文件或拖拽到此":auto-submit="false":limit-count="9":limit-size="50":upload-method="uploadMethod"></vxe-upload></div>
</template><script setup>
import { ref } from 'vue'
import axios from 'axios'const refUpload = ref()
const fileList = ref([])const uploadMethod = ({ file, updateProgress }) => {const formData = new FormData()formData.append('file', file)return axios.post('/api/pub/upload/single', formData, {onUploadProgress (progressEvent) {const percentCompleted = Math.round((progressEvent.loaded * 100) / (progressEvent.total || 0))updateProgress(percentCompleted)}}).then((res) => {return {...res.data}})
}const submitEvent = () => {const $upload = refUpload.valueif ($upload) {$upload.submit()}
}
</script>

上传附件,可以单个点击上传、也可以批量上传

还可以通过 show-submit-button 显示上传按钮,单个提交或者手动提交单个。如果上传失败也可以通过 show-error-status 显示重新上传按钮

在这里插入图片描述

<template><div><vxe-button status="primary" @click="submitEvent">点击手动上传</vxe-button><vxe-uploadmultipleshow-progressshow-submit-buttonshow-error-statusv-model="fileList"ref="refUpload"button-text="选择文件或拖拽到此":auto-submit="false":limit-count="9":limit-size="50":upload-method="uploadMethod"></vxe-upload></div>
</template><script setup>
import { ref } from 'vue'
import axios from 'axios'const refUpload = ref()
const fileList = ref([])const uploadMethod = ({ file, updateProgress }) => {const formData = new FormData()formData.append('file', file)return axios.post('/api/pub/upload/single?randomError=1', formData, {onUploadProgress (progressEvent) {const percentCompleted = Math.round((progressEvent.loaded * 100) / (progressEvent.total || 0))updateProgress(percentCompleted)}}).then((res) => {return {...res.data}})
}const submitEvent = () => {const $upload = refUpload.valueif ($upload) {$upload.submit(true)}
}
</script>

上传图片的详细用法看这里

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/913138.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/913138.shtml
英文地址,请注明出处:http://en.pswp.cn/news/913138.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leaflet【十一】地图瓦片路径可视化

前言 在开发调试过程当中&#xff0c;如果引入的是公司内部的Gis地图信息或者一些第三方定制来的Gis地图数据&#xff0c;当某一些地图块数据缺失的时候&#xff0c;要打开F12去一个个找那些链接&#xff08;去找对应的xy与layer&#xff09;失效、那么你可能需要使用以下插件…

ES6从入门到精通:模块化

ES6 模块化基础概念ES6 模块化是 JavaScript 官方标准&#xff0c;通过 import 和 export 语法实现代码拆分与复用。模块化特点包括&#xff1a;每个文件是一个独立模块&#xff0c;作用域隔离。支持静态分析&#xff0c;依赖关系在编译时确定。输出的是值的引用&#xff08;动…

stm32 USART串口协议与外设——江协教程踩坑经验分享

江协stm32学习&#xff1a;9-1~9-3 USART串口协议与外设 一、串口通信基础知识 1、通信类型&#xff1a; 全双工通信&#xff1a;通信双方能够同时进行双向通信。一般有两根通信线&#xff0c;如USART中的TX&#xff08;发送&#xff09;和RX&#xff08;接收&#xff09;线&am…

深度学习中的一些名词

向前传播 forward pass 在机器学习中&#xff0c;输入的feature, 通过预测模型&#xff0c;输出预测值&#xff0c;此过程称之为向前传播&#xff1b; 向后传播 backward pass 为了将预测与真实值的产值减小&#xff0c;需要根据差值&#xff0c;更新模型中的参数&#xff0c;此…

鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)

项目概述 基于鸿蒙&#xff08;OpenHarmony&#xff09;平台开发的手势密码锁应用&#xff0c;旨在为用户提供安全、便捷且具有良好交互体验的身份验证方式。通过手势图案输入&#xff0c;用户可以轻松设置和验证密码&#xff0c;提升设备的安全性和个性化体验。 功能特点 手…

vue文本插值

好的&#xff0c;我们来详细讲解 Vue 中最基础的数据展示方式&#xff1a;文本插值和在其内部使用的 JavaScript 表达式。 1. 文本插值 (Text Interpolation) 知识点: 文本插值是 Vue 中最基本的数据绑定形式。它使用“Mustache”语法&#xff08;双大括号 {{ }}&#xff09;…

Python:线性代数,向量内积谐音记忆。

目录1 先说结论2 解释3 欢迎纠错4 论文写作/Python 学习智能体------以下关于 Markdown 编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、…

小程序导航设置更多内容的实现方法

在小程序中实现导航栏设置更多内容&#xff0c;可以通过以下几种方式实现&#xff1a; 1. 使用原生导航栏自定义按钮 javascript // app.json 或页面.json中配置 {"navigationBarTitleText": "首页","navigationBarTextStyle": "black&q…

SpringBoot 解决配置文件有黄色波浪线

在application.properties配置文件中有黄色波浪线&#xff0c;是警告!! 原因&#xff1a;编码格式不一致&#xff01;&#xff01; 解决&#xff1a;Settings| Editor | File Encodings | 选择UTF-8

在 Vue 3 中全局使用 Suspense 组件

Suspense 是 Vue 3 引入的一个内置组件&#xff0c;不需要引用可以直接用。用于处理异步依赖的等待状态。虽然 Suspense 主要用于异步组件&#xff0c;但你也可以全局地使用它来管理整个应用的加载状态。 全局 Suspense 的基本用法 1. 在根组件中使用 Suspense // main.js 或…

笔记/计算机网络

Content 计算机网络部分核心概念十大网络协议一览 计算机网络部分核心概念 1. 什么是计算机网络&#xff1f;它最基本的功能是什么&#xff1f; 计算机网络是指通过某种传输介质将多台独立的计算机或设备连接起来&#xff0c;实现数据交换和资源共享的系统。其最基本的功能是数…

时频图数据集更正程序,去除坐标轴白边及调整对应的标签值

当数据集是时频图时可能有一个尴尬的问题&#xff0c;就是数据集制作好后&#xff0c;发现有白边。 其实这也不影响训练模型&#xff0c;可能对模型训练效果的影响也是微乎其微的&#xff0c;于是大多数情况我会选择直接用整张图片训练模型。但是&#xff0c;有的情况下&#x…

mv重命名报错:bash:未预期的符号 ‘(‘附近有语法错误

文章目录 一、报错背景二、解决方法2.1、方法一&#xff1a;文件名加引号2.2、方法二&#xff1a;特殊字符前加\进行转义 一、报错背景 在linux上对一文件执行重命名时报错。原因是该文件名包含空格与括号。 文件名如下&#xff1a; aa &#xff08;1).txt执行命令及报错如下…

Unity-MMORPG内容笔记-其三

继续之前的内容&#xff1a; 战斗系统 无需多言&#xff0c;整个项目中最复杂的部分&#xff0c;也是代码量最大的部分。 属性系统 首先我们要定义一系列属性&#xff0c;毕竟所谓的战斗就是不断地扣血对吧。 属性系统是战斗系统的核心模块&#xff0c;负责管理角色的所有…

Linux入门篇学习——Linux 帮助手册

目录 一、Linux 帮助手册 1.怎么打开帮助手册 2.安装依赖 3.使用手册查看命令 一、Linux 帮助手册 1.怎么打开帮助手册 打开 ubuntu &#xff0c;输入 man 命令打开帮助手册&#xff0c;直接在控制台输入 man 就可以了&#xff0c; man 手册一共有 9 页&#xff0c…

2025年后端主流框架对比和竞争格局及趋势发展

2025年的后端开发呈现出云原生主导、性能革命、AI深度融合的技术格局&#xff0c;主流框架在细分领域持续分化&#xff0c;新兴技术快速渗透关键场景。以下是基于行业实践与技术演进的深度解析&#xff1a; 一、主流框架竞争态势与核心能力 1. Java生态&#xff1a;企业级市场的…

bRPC简介

bRPC基础介绍。 什么是RPC? 互联网上的机器大都通过TCP/IP协议相互访问&#xff0c;但TCP/IP只是往远端发送了一段二进制数据&#xff0c;为了建立服务还有很多问题需要抽象&#xff1a; 数据以什么格式传输&#xff1f;不同机器间&#xff0c;网络间可能是不同的字节序&am…

力扣网C语言编程题:在数组中查找目标值位置之二分查找法

一. 简介 上一篇文章对力扣网上"有序数组中查找目标值范围"题目进行了普通的解法。文章如下&#xff1a; 力扣网C语言编程题&#xff1a;在数组中查找目标值位置之暴力解法-CSDN博客 本文使用二分查找法进行实现&#xff0c;因为二分查找法符合题目要求&#xff0…

前端查询条件加密传输方案(SM2加解密)

一、需求背景 控台项目甲方进行安全测试&#xff0c;测试报告其中一条&#xff1a;敏感信息明文传输 1 敏感信息明文传输 中危 查询接口传输手机号、银行卡号等敏感信息时未加密/脱敏处理。 二、解决方案 讨论出的方案是通过前端查询条件加密&#xff0c;后端对加密的…

【Python】Flask网页

Flask第三方库安装命令&#xff1a;pip install flask代码&#xff1a;from flask import Flask app Flask(__name__)app.route("/") def hello():return "Hello world!"if __name__ "__main__":app.run()其中的"Hello world!"可以改…