下载.txt文件 方法有哪些?

1.1. a标签行内 默认 :get请求

html 复制代码
<a href="your-file.pdf" download="desired-filename.pdf">下载文件</a>

1.2. a标签另一种方式

html代码 👇

html 复制代码
<button onclick="downloadCSV()">下载CSV文件</button> 

js代码👇

javascript 复制代码
function downloadCSV() {  
    // 示例CSV数据  
    var csv = "姓名,年龄,职业\n张三,30,软件工程师\n李四,25,数据分析师";  
  
    // 创建一个Blob对象  
    var blob = new Blob([csv], { type: "text/csv;charset=utf-8;" });  
  
    // 创建一个指向Blob的URL  
    var url = URL.createObjectURL(blob);  
  
    // 创建一个a标签并设置属性  
    var a = document.createElement("a");  
    a.href = url;  
    a.download = "example.csv"; // 设置下载文件名  
    document.body.appendChild(a); // 将a标签添加到body中(虽然这一步并非必需,但可以避免某些浏览器的安全限制)  
    a.click(); // 模拟点击以触发下载  
  
    // 清理:从body中移除a标签,并释放URL对象  
    document.body.removeChild(a);  
    window.URL.revokeObjectURL(url);  
} 

2、下载文件 post 请求

html代码👇

html 复制代码
<div @click="downloadData">
    下载表格数据
</div>

js代码👇

javascript 复制代码
    downloadData() {
      downloadData().then(res => {
        // 假设 data 是返回来的二进制数据 const data = res.data
        const url = window.URL.create0bjectURL(
          new Blob([data],{ type: "a application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"})
        )
        const link = document.createElement('a')
        link.style.display = 'none'
        link.href = url
        link.setAttribute('download', 'excel.xlsx')
        document.body.appendChild(link)
        link.click()
        document.body.removeChild(link)
      })
    },

index.js接口文件👇

javascript 复制代码
   export function getDownloadData (data) {	
	 return request({	
	   url: '/soft/downloadApi',	
	   method: 'post',	
	   data: data,	
	   responseType:'blob'	//这个很重要
	})
相关推荐
鱼跃鹰飞2 小时前
设计模式系列:工厂模式
java·设计模式·系统架构
我是伪码农2 小时前
Vue 1.23
前端·javascript·vue.js
a努力。2 小时前
国家电网Java面试被问:混沌工程在分布式系统中的应用
java·开发语言·数据库·git·mysql·面试·职场和发展
Yvonne爱编码2 小时前
Java 四大内部类全解析:从设计本质到实战应用
java·开发语言·python
wqwqweee2 小时前
Flutter for OpenHarmony 看书管理记录App实战:搜索功能实现
开发语言·javascript·python·flutter·harmonyos
J2虾虾2 小时前
SpringBoot和mybatis Plus不兼容报错的问题
java·spring boot·mybatis
毕设源码-郭学长3 小时前
【开题答辩全过程】以 基于springboot 的豪华婚车租赁系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
HIT_Weston4 小时前
107、【Ubuntu】【Hugo】搭建私人博客:模糊搜索 Fuse.js(三)
linux·javascript·ubuntu
Tao____5 小时前
通用性物联网平台
java·物联网·mqtt·低代码·开源
曹轲恒5 小时前
SpringBoot整合SpringMVC(上)
java·spring boot·spring