vue上传文件时显示上传进度

news/2025/2/12 18:10:17/

要在Vue中显示文件上传进度,可以使用axios库来处理文件上传,并使用axios的onUploadProgress方法获取上传进度。

首先,确保你已经安装了axios库。可以使用npm或yarn安装,在终端中运行以下命令:

npm install axios

或者

yarn add axios

接下来,在你的Vue组件中引入axios库,并添加一个处理文件上传的方法。例如,在App.vue组件中:

<template><div><input type="file" @change="uploadFile" /><p v-if="uploadProgress">上传进度: {{ uploadProgress }}%</p></div>
</template><script>
import axios from 'axios';export default {data() {return {uploadProgress: 0,};},methods: {uploadFile(event) {const file = event.target.files[0];const formData = new FormData();formData.append('file', file);axios.post('/upload', formData, {headers: {'Content-Type': 'multipart/form-data',},onUploadProgress: (progressEvent) => {this.uploadProgress = Math.round((progressEvent.loaded / progressEvent.total) * 100);},}).then((response) => {console.log(response.data);}).catch((error) => {console.log(error);});},},
};
</script>

上述代码中,我们首先引入了axios库,并在组件的data选项中添加了一个uploadProgress属性,用于存储上传进度。在uploadFile方法中,我们获取到文件对象,并创建一个FormData对象来存储文件数据。然后,我们使用axios库的post方法发送文件上传请求,并传入FormData对象作为请求数据。在请求配置选项中,我们添加了headers选项来设置请求头的Content-Typemultipart/form-data,以支持文件上传。同时,我们使用onUploadProgress方法来监听上传进度事件,并将进度以百分比的形式存储在uploadProgress属性中。最后,我们处理上传成功和失败的回调函数。

在模板中,我们添加了一个文件输入框,当选择一个文件时,会触发uploadFile方法进行文件上传。同时,在模板中我们使用v-if指令来判断是否显示上传进度,如果uploadProgress大于0,则会显示上传进度。

请注意,上述代码中的/upload路径是一个示例,你需要根据你的后端API地址进行相应调整。同时,你需要在后端服务器上处理文件上传请求,将上传的文件保存到服务器或云存储中。具体如何处理文件上传请求,取决于你使用的后端框架和存储解决方案。


http://www.ppmy.cn/news/1299172.html

相关文章

springCould中的Bus-从小白开始【11】

目录 &#x1f9c2;1.Bus是什么❤️❤️❤️ &#x1f32d;2.什么是总线❤️❤️❤️ &#x1f953;3.rabbitmq❤️❤️❤️ &#x1f95e;4.新建模块3366❤️❤️❤️ &#x1f373;5.设计思想 ❤️❤️❤️ &#x1f37f;6.添加消息总线的支持❤️❤️❤️ &#x1f9…

第二百五十七回

文章目录 概念介绍使用方法示例代码 我们在上一章回中介绍了通道相关的内容&#xff0c;本章回中将介绍StreamProvider组件.闲话休提&#xff0c;让我们一起Talk Flutter吧。 概念介绍 在Flutter中Stream是经常使用的组件&#xff0c;对该组件的监听可void main() { ///让状态…

超维空间M1无人机使用说明书——52、ROS无人机二维码识别与降落

引言&#xff1a;使用二维码引导无人机实现精准降落&#xff0c;首先需要实现对二维码的识别和定位&#xff0c;可以参考博客的二维码识别和定位内容。本小节主要是通过获取拿到的二维码位置&#xff0c;控制无人机全向的移动和降落&#xff0c;分为两种&#xff0c;一种是无人…

[后端] 微服务的前世今生

微服务的前世今生 整体脉络: 单体 -> 垂直划分 -> SOA -> micro service 微服务 -> services mesh服务网格 -> future 文章目录 微服务的前世今生单一应用架构特征优点&#xff1a;缺点&#xff1a; 垂直应用架构特征优点缺点 SOA 面向服务架构特征优点缺点 微服…

【QML COOK】- 006-用C++定义一个QML元素类型

Qt原本是一个C图形框架&#xff0c;因此QML也少不了C。QML通常只负责显示&#xff0c;而后台逻辑由C实现&#xff0c;因此掌握C和QML之间的交互非常必要。 本例实现一个最简单的例子&#xff0c;用C定义一个QML的元素类型并在QML使用它。 需求是在窗口上显示鼠标点击的次数。…

【leetcode】字符串中的第一个唯一字符

题目描述 给定一个字符串 s &#xff0c;找到 它的第一个不重复的字符&#xff0c;并返回它的索引 。如果不存在&#xff0c;则返回 -1 。 用例 示例 1&#xff1a; 输入: s “leetcode” 输出: 0 示例 2: 输入: s “loveleetcode” 输出: 2 示例 3: 输入: s “aabb”…

网络协议与攻击模拟_03实施ARP欺骗和攻击

一、ARP攻击 1、实验环境 kali Linux &#xff08;安装arpspoof工具&#xff09;被攻击主机 2、kali配置 kali Linux系统是基于debian Linux系统&#xff0c;采用deb包管理方式&#xff0c;可以使用apt源的方式进行直接从源的安装。 配置kali网络源 vim /etc/apt/sources…

如何通过兴趣爱好选职业?

一个错误的选择&#xff0c;可能造成终身的遗憾&#xff0c;一个正确的选择&#xff0c;可以让我们少奋斗几十年。所以无论现在付出多少代价&#xff0c;多花一些时间&#xff0c;去研究以下未来的职业方向&#xff0c;这是值得的。 职业定位&#xff08;专业定位&#xff09;…