vue2 使用axios 请求后台返回文件流导出为excel

目录

[步骤 1: 安装 Axios](#步骤 1: 安装 Axios)

[步骤 2: 创建 Axios 实例](#步骤 2: 创建 Axios 实例)

[步骤 3: 发起请求并处理文件流](#步骤 3: 发起请求并处理文件流)

说明


步骤 1: 安装 Axios

首先,确保项目中已经安装了 Axios。如果没有,可以通过以下命令进行安装:

bash 复制代码
npm install axios

步骤 2: 创建 Axios 实例

为了更好地管理 Axios 配置,可以创建一个 Axios 实例。例如,在 src 目录下创建一个 axiosInstance.js 文件:

javascript 复制代码
import axios from 'axios';

const axiosInstance = axios.create({
  baseURL: 'http://your-api-base-url.com', // 替换为你的后端 API 基础 URL
  responseType: 'blob' // 设置响应类型为 blob
});

export default axiosInstance;

步骤 3: 发起请求并处理文件流

在 Vue 组件中使用这个 Axios 实例发起请求,并处理返回的文件流以导出 Excel 文件。

例如,在 src/views/user/index.vue 文件中:

javascript 复制代码
<template>
  <div>
    <button @click="downloadExcel">导出 Excel</button>
  </div>
</template>

<script>
import axiosInstance from '@/axiosInstance';

export default { 
  methods: {
    async downloadExcel() {
      try {
        const response = await axiosInstance.get('api地址', {
          params: {
           //传入查询参数
          }
        });

        // 创建一个 blob 对象
        const blob = new Blob([response.data], { type: 'application/vnd.ms-excel' });

        // 创建一个链接元素
        const link = document.createElement('a');
        link.href = window.URL.createObjectURL(blob);
        link.download = 'exported-file.xlsx'; // 设置下载文件名
        link.click();

        // 释放 URL 对象
        window.URL.revokeObjectURL(link.href);
      } catch (error) {
        console.error('导出excel失败', error);
      }
    }
  }
};
</script>

说明

  1. 配置 Axios 实例 :我们创建了一个 Axios 实例并将 responseType 设置为 blob,以便 Axios 将响应数据处理为文件流。

  2. 发起请求 :在 downloadExcel 方法中,我们使用 axiosInstance.get 方法发起 GET 请求。如果需要传递查询参数,可以通过 params 选项传递。

  3. 处理文件流 :请求成功后,我们将响应数据创建为一个 Blob 对象,并将其类型设置为 application/vnd.ms-excel。然后,我们创建一个临时的链接元素,设置其 href 属性为 Blob 对象的 URL,并调用 click 方法触发下载。下载完成后,释放 URL 对象以避免内存泄漏。

相关推荐
Curvatureflight14 小时前
前端国际化 i18n 落地实践:语言包、动态文案和格式化问题怎么处理?
前端·c++·vue
乐于分享的阿乐15 小时前
最新长期支持版本nodejs安装及环境配置(保姆级图文+安装包)
node.js
m0_5358175515 小时前
macOS上Claude Code安装配置保姆级教程:国内直连API,从0到1跑通(附避坑指南)
gpt·macos·ai·node.js·claude·claudecode·88api
五月君_17 小时前
放弃 Python,Kimi 用 TS + Node.js 重写了一个 Kimi Code
开发语言·python·node.js
优雅格子衫19 小时前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
路光.19 小时前
uniapp中解决webview在app中调用,有过渡空白问题,增加过渡动效
uni-app·vue·app·uniapp
涛声依旧-底层原理研究所20 小时前
Node.js在高并发低延迟场景中的优势
java·人工智能·python·node.js
晓杰'20 小时前
从0到1实现Balatro游戏后端(5):得分计算与单局结算流程实现
后端·typescript·node.js·游戏开发·项目实战·nestjs·webscoket
参宿721 小时前
Shell 脚本语言(Bash/Sh)基础 与 应用
node.js
weifengma-wish1 天前
通过NPM安装claude code
前端·npm·node.js