vue3+axios请求导出excel文件

在Vue 3中使用axios请求导出Excel文件,可以发送一个GET或POST请求,并设置响应类型为blob或arraybuffer,然后使用new Blob()构造函数创建一个二进制文件,最后使用URL.createObjectURL()生成一个可以下载的链接。

先看代码

复制代码
import axios from 'axios';
 
// 导出Excel文件的函数
export function exportExcel() {
  const url = '/api/export'; // 替换为你的接口地址
  axios({
    method: 'get',
    url: url,
    responseType: 'blob', // 重要!设置响应类型为blob或arraybuffer
  })
  .then(response => {
    // 创建一个新的Blob对象,设置文件类型
//response.data是后端返回的文件流数据,如果response是文件流就直接用response,根据后端返回实际情况而定
    const blob = new Blob([response.data], { type: 'application/vnd.ms-excel;charset=UTF-8' });
    // 创建一个指向新Blob对象的URL
    const url = window.URL.createObjectURL(blob);
    // 创建一个a标签用于下载
    const link = document.createElement('a');
    link.href = url;
    link.setAttribute('download', 'export.xls'); // 设置下载文件名
    document.body.appendChild(link);
    // 触发下载
    link.click();
    // 清理并移除元素和对象URL
    document.body.removeChild(link);
    window.URL.revokeObjectURL(url);
  })
  .catch(error => {
    console.error('导出Excel失败:', error);
  });
}

后端返回的数据是一个二进制数据流,可以console.log(response)打印一下响应数据,查看数据是不是Blob类型,如果不是的话可能会出现乱码、undefined等情况

以arraybuffer类型为准的post请求,以下是后端返回数据截图,这里response的值是文件流

后端返回的数据

响应拦截器获取到的数据

打印的response数据

如果前端得到的数据结构跟上面截图一样,大概是没有问题的,如果出现中文乱码、undefined等情况,可以检查一下是否在请求时设置了响应类型,blob和arraybuffer还是有区别的,blob不行就试试arraybuffer

相关推荐
SuperEugene1 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
子兮曰2 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun
Setsuna_F_Seiei2 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
wefly20172 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
英俊潇洒美少年3 小时前
vue如何实现react useDeferredvalue和useTransition的效果
前端·vue.js·react.js
英俊潇洒美少年3 小时前
ref 底层到底是怎么变成响应式的?
vue.js
kyriewen114 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
英俊潇洒美少年4 小时前
react19和vue3的优缺点 对比
前端·javascript·vue.js·react.js
多看书少吃饭5 小时前
Vue + Java + Python 打造企业级 AI 知识库与任务分发系统(RAG架构全解析)
java·vue.js·笔记
~无忧花开~6 小时前
React生命周期全解析
开发语言·前端·javascript·react.js·前端框架·react