Vue中下载不同文件的几种方式
当在Vue中需要实现文件下载功能时,我们可以有多种方式来完成。下面将介绍五种常用的方法。
1. 使用window.open方法下载文件
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
export default {methods: {downloadFile(fileName) {const fileUrl = '/path/to/' + fileName; // 文件的URL地址window.open(fileUrl);}}
};
</script>
在上面的示例中,我们使用了window.open方法来打开一个新窗口,并直接访问文件的URL地址,从而触发文件下载。
2. 使用<a>标签进行文件下载
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
export default {methods: {downloadFile(fileName) {const fileUrl = '/path/to/' + fileName; // 文件的URL地址const link = document.createElement('a');link.href = fileUrl;link.setAttribute('download', fileName);link.click();}}
};
</script>
在上面的示例中,我们首先创建一个<a>标签,然后设置其href属性为文件的URL地址,download属性为要下载的文件名。最后,通过调用click()方法触发链接的点击事件,实现文件的下载。
3. 使用axios下载文件
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
import axios from 'axios';export default {methods: {downloadFile(fileName) {const fileUrl = '/path/to/' + fileName; // 文件的URL地址axios.get(fileUrl, { responseType: 'blob' }).then(response => {const url = window.URL.createObjectURL(new Blob([response.data]));const link = document.createElement('a');link.href = url;link.setAttribute('download', fileName);document.body.appendChild(link);link.click();}).catch(error => {console.error(error);});}}
};
</script>
在上面的示例中,我们使用了axios发送GET请求,设置responseType为blob以便获取文件的二进制数据。然后,通过创建临时URL、创建<a>标签并设置下载属性,实现文件的下载。
4. 使用Fetch API下载文件
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
export default {methods: {downloadFile(fileName) {const fileUrl = '/path/to/' + fileName; // 文件的URL地址fetch(fileUrl).then(response => response.blob()).then(blob => {const url = window.URL.createObjectURL(blob);const link = document.createElement('a');link.href = url;link.setAttribute('download', fileName);document.body.appendChild(link);link.click();}).catch(error => {console.error(error);});}}
};
</script>
在上面的示例中,我们使用了Fetch API发送GET请求,并使用.blob()方法将返回的数据转换为blob对象。然后,通过创建临时URL、创建<a>标签并设置下载属性,实现文件的下载。
5. 使用Vue的$download方法下载文件
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
export default {methods: {downloadFile(fileName) {const fileUrl = '/path/to/' + fileName; // 文件的URL地址this.$download(fileUrl, fileName);}}
};
</script>
在这个示例中,我们直接调用Vue实例的$download方法,并传入文件的URL地址和下载的文件名,即可实现文件的下载。
6. 使用创建a标签方法下载文件
<template><div><button @click="downloadFile('file1.pdf')">下载文件1</button><button @click="downloadFile('file2.jpg')">下载文件2</button></div>
</template><script>
export default {methods: {downloadFile(fileName) {const folderPath = '/path/to/folder/'; // 文件所在的文件夹路径const fileUrl = folderPath + fileName; // 拼接文件夹路径和文件名const link = document.createElement('a');link.href = fileUrl;link.setAttribute('download', fileName);link.click();}}
};
</script>
在这个示例中,我们首先定义了文件所在的文件夹路径folderPath,然后通过拼接文件夹路径和文件名来构建完整的文件URL地址fileUrl。接着,我们创建一个<a>标签,并设置其href属性为文件URL,download属性为要下载的文件名。最后,通过调用click()方法触发链接的点击事件,实现文件的下载。
以上是六种常用的在Vue中实现文件下载的方式,请根据项目需求选择合适的方式来完成文件下载功能。
相关文章:
Vue中下载不同文件的几种方式
当在Vue中需要实现文件下载功能时,我们可以有多种方式来完成。下面将介绍五种常用的方法。 1. 使用window.open方法下载文件 <template><div><button click"downloadFile(file1.pdf)">下载文件1</button><button click"…...
Ethernet/ip协议开发记录
目录 简介 一:EtherNet/IP 二:CIP 1. CIP 对象模型 2. CIP 服务 3. CIP 对象库...
Spring系列三:基于注解配置bean
文章目录 💗通过注解配置bean🍝基本介绍🍝快速入门🍝注意事项和细节 💗自己实现Spring注解配置Bean机制🍝思路分析🍝注意事项和细节 💗自动装配 Autowired🍝案例1: Autow…...
git的简单介绍和使用
git学习 1. 概念git和svn的区别和优势1.1 区别1.2 git优势 2. git的三个状态和三个阶段2.1 三个状态:2.2 三个阶段: 3. 常用的git命令3.1 下面是最常用的命令3.2 git命令操作流程图如下: 4. 分支内容学习4.1 项目远程仓库4.2 项目本地仓库4.3…...
UNet Model
论文地址 第一阶段 conv2d(33) first conv:5725721 → 57057064 second conv:57057064 → 56856864 代码 # first 33 convolutional layer self.first nn.Conv2d(in_channels, out_channels, kernel_size3, padding1) self.act1 nn.ReLU() # Seco…...
vue+iviewUi+oss直传阿里云上传文件
前端实现文件上传到oss(阿里云)适用于vue、react、uni-app,获取视频第一帧图片 用户获取oss配置信息将文件上传到阿里云,保证了安全性和减轻服务器负担。一般文件资源很多直接上传到服务器会加重服务器负担此时可以选择上传到oss&…...
算法leetcode|68. 文本左右对齐(rust重拳出击)
文章目录 68. 文本左右对齐:样例 1:样例 2:样例 3:提示: 分析:题解:rust:go:c:python:java: 68. 文本左右对齐: 给定一个…...
基于MATLAB实现小波算法仿真(附上多个完整源码+数据集)
小波变换是一种常用的信号处理技术,广泛应用于图像处理、音频处理、压缩等领域。本文将介绍MATLAB中小波变换的基本原理和实现方法,并给出一个示例来说明如何使用MATLAB进行小波变换和逆变换。 文章目录 1. 引言2. 小波变换的基本原理3. MATLAB中的小波变…...
【深度学习注意力机制系列】—— CBAM注意力机制(附pytorch实现)
CBAM(Convolutional Block Attention Module)是一种用于增强卷积神经网络(CNN)性能的注意力机制模块。它由Sanghyun Woo等人在2018年的论文[1807.06521] CBAM: Convolutional Block Attention Module (arxiv.org)中提出。CBAM的主…...
【资料分享】全志科技T507-H工业核心板规格书
1 核心板简介 创龙科技SOM-TLT507是一款基于全志科技T507-H处理器设计的4核ARM Cortex-A53全国产工业核心板,主频高达1.416GHz。核心板CPU、ROM、RAM、电源、晶振等所有元器件均采用国产工业级方案,国产化率100%。 核心板通过邮票孔连接方式引出MIPI C…...
Profibus-DP转modbus RTU网关modbus rtu和tcp的区别
捷米JM-DPM-RTU网关在Profibus总线侧实现主站功能,在Modbus串口侧实现从站功能。可将ProfibusDP协议的设备(如:EH流量计、倍福编码器等)接入到Modbus网络中;通过增加DP/PA耦合器,也可将Profibus PA从站接入…...
AlmaLinux 9 安装 Edge 和 Chrome
AlmaLinux 9 安装 Edge 和 Chrome 1. 安装 Edge2. 安装 Chrome 1. 安装 Edge 更新源, sudo dnf update -y # sudo dnf install dnf-utils -y添加 Edge 源, sudo dnf config-manager --add-repo https://packages.microsoft.com/yumrepos/edge再次更新…...
NGINX——负载均衡
负载均衡————>通过反向代理来实现 nginx反向代理的七层代理和四层代理 七层代理: 七层代理时最常用的反向代理方式,其只能配置在nginx的配置文件的http模块中,而且方法名称必须要定义成“upstream”模块,注意不能写在se…...
C#实现端口扫描和执行cmd命令、调用摄像头
C#端口扫描 using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Sockets; using System.Threading;namespace PortScanner {class Program{static void Main(string[] args){// 设置扫描参数string host "localho…...
【图像恢复】基于交替乘子方法(ADMM)图像恢复算法研究[固定点收敛和应用](Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
Qt 使用QLabel的派生类实现QLabel的双击响应
1 介绍 在QLabel中没有双击等事件响应,需要构建其派生类,自定义信号(signals)、重载事件函数(event),最后在Qwidget中使用connect链接即可,进而实现响应功能。 对于其余没有需求事件响应的QObject同样适用。 此外,该功…...
关于@JSONField的使用
1.此注解来自jar包com.alibaba.fastjson 今天分享一个有意思的事情。这个注解作用与类的属性上,如下: ApiModelProperty(value"开始时间,格式:yyyy-MM-dd",required true) JSONField(name"start_date",ordinal 1) private String…...
Centos7单机部署ElasticSearch
Centos7单机部署ElasticSearch 引言 Elasticsearch是一种广泛使用的开源搜索引擎,专门为分布式环境设计,但也可以在单机上运行。它使存储、搜索和分析大量数据变得更加容易和高效。此教程将引导你通过在Centos7上单机部署Elasticsearch,涵盖…...
js玩儿爬虫
前言 提到爬虫可能大多都会想到python,其实爬虫的实现并不限制任何语言。 下面我们就使用js来实现,后端为express,前端为vue3。 实现功能 话不多说,先看结果: 这是项目链接:https://gitee.com/xi1213/w…...
【数据结构与算法】第38篇:图论(二):深度优先搜索(DFS)与广度优先搜索(BFS)
一、图遍历的基本概念1.1 为什么需要遍历和树一样,图也需要一种方式“访问”所有顶点。但图可能有环,所以需要标记已访问的顶点,避免重复访问。1.2 两种遍历方式遍历方式核心思想数据结构DFS一条路走到底,回溯栈(递归&…...
frpc-desktop自动化版本号管理:使用standard-version
frpc-desktop自动化版本号管理:使用standard-version 在开源项目开发中,手动管理版本号和更新日志不仅繁琐,还容易出错。本文将介绍如何在frpc-desktop项目中集成standard-version工具,实现版本号自动递增、CHANGELOG.md自动生成…...
VideoAgentTrek Screen Filter部署排错大全:从403 Forbidden到GPU内存不足
VideoAgentTrek Screen Filter部署排错大全:从403 Forbidden到GPU内存不足 部署AI视频处理工具,最怕的就是遇到各种报错,尤其是当你满怀期待地敲下运行命令,屏幕上却弹出一堆看不懂的红色错误信息时,那种感觉真是让人…...
Diablo16串口库:Arduino驱动4D Systems图形屏实战指南
1. Diablo16-Serial-Arduino-Library 项目概述Diablo16-Serial-Arduino-Library 是一个专为 Arduino 平台设计的串行通信封装库,用于与 4D Systems 公司基于 Diablo16 图形处理器(GPU)的显示模块进行高效、可靠的指令交互。该库并非直接驱动 …...
终极RDP Wrapper配置指南:解锁Windows多用户远程桌面全功能
终极RDP Wrapper配置指南:解锁Windows多用户远程桌面全功能 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap 还在为Windows远程桌面的"不支持"状态而烦恼吗?🤔 RDP Wra…...
别再手动改指纹了!用这个Chrome 116内核的免费工具,5分钟搞定WebRTC、Canvas等关键指纹伪装
浏览器指纹伪装实战指南:5分钟实现全方位隐私保护 每次打开电商网站,首页推荐的商品总是精准得令人毛骨悚然;刚搜索过某个产品,社交平台立刻出现相关广告——这些现象背后,是网站通过浏览器指纹对用户进行的追踪。传统…...
电容是什么?一个“快充快放”的微型充电宝轮
一、前言:什么是 OFA VQA 模型? OFA(One For All)是字节跳动提出的多模态预训练模型,支持视觉问答、图像描述、图像编辑等多种任务,其中视觉问答(VQA)是最常用的功能之一——输入一张…...
ros2中可视化topic数值命令
ros2 run plotjuggler plotjuggler...
终极DLSSTweaks配置指南:5步快速解锁NVIDIA DLSS隐藏画质
终极DLSSTweaks配置指南:5步快速解锁NVIDIA DLSS隐藏画质 【免费下载链接】DLSSTweaks Tweak DLL for NVIDIA DLSS, force DLAA on DLSS-supported titles, tweak scaling ratios & DLSS 3.1 presets, override DLSS versions without overwriting game files. …...
软著申请避坑指南:为什么你的大学生创新项目总被驳回?
大学生软著申请避坑指南:从驳回案例看审核要点 1. 软著申请为何频频被驳回? 每年有大量大学生在申请软著时遭遇驳回,这不仅耽误了宝贵的时间,还可能影响保研加分、奖学金评定等重要事项。根据中国版权保护中心的数据,大…...
