前端导出 Word/Excel/PDF 文件

核心思路是:后端返回文件二进制流 → 前端接收并转换为 Blob → 创建下载链接触发保存

一、核心实现步骤(通用逻辑)

  1. 后端接口需返回 文件二进制流(Content-Type 对应文件类型),而非 JSON。
  2. 前端请求时设置 responseType: 'blob',确保接收二进制数据。
  3. 将 Blob 转换为临时下载链接,模拟点击实现文件保存。
  4. 清理临时链接,避免内存泄漏。

二、完整代码实现(Axios 版本,最常用)

1. 导出 Excel 文件(.xlsx)

javascript 复制代码
// 安装依赖:npm install axios
import axios from 'axios';

/**
 * 导出Excel文件
 * @param {string} apiUrl - 接口地址
 * @param {object} params - 接口参数(如筛选条件)
 * @param {string} fileName - 自定义文件名(无需后缀)
 */
export const exportExcel = async (apiUrl, params, fileName = '导出数据') => {
  try {
    // 1. 发送请求,指定接收二进制流
    const response = await axios({
      url: apiUrl,
      method: 'GET', // 也可POST,根据后端接口调整
      params: params, // POST请用data: params
      responseType: 'blob', // 关键:指定返回Blob类型
      headers: {
        'Content-Type': 'application/json', // 根据后端要求调整
        // 如有token,添加认证:
        // 'Authorization': `Bearer ${localStorage.getItem('token')}`
      }
    });

    // 2. 处理返回的Blob数据
    const blob = new Blob([response.data], {
      type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' // Excel MIME类型
    });

    // 3. 创建临时下载链接
    const downloadUrl = window.URL.createObjectURL(blob);
    const link = document.createElement('a');
    link.href = downloadUrl;
    link.download = `${fileName}.xlsx`; // 文件名+后缀
    document.body.appendChild(link);

    // 4. 触发下载
    link.click();

    // 5. 清理资源
    document.body.removeChild(link);
    window.URL.revokeObjectURL(downloadUrl);

    console.log('Excel文件导出成功');
  } catch (error) {
    console.error('Excel导出失败:', error);
    alert('文件导出失败,请重试');
  }
};

// 调用示例
// exportExcel('/api/export/user', { department: '技术部' }, '技术部用户列表');

2. Blob的type值

  • 如果你的接口返回的是 .xls 格式(旧版二进制),就用:

    go 复制代码
    const type = 'application/vnd.ms-excel';
    const blob = new Blob([response.data], { type: type });

    下载时文件名后缀用 .xls

  • 如果接口返回的是 .xlsx 格式(新版 XML),就用:

    go 复制代码
    const type = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
    const blob = new Blob([response.data], { type: type });

    下载时文件名后缀用 .xlsx

⚠️ 注意:MIME 类型必须和实际文件格式一致,否则可能导致下载的文件无法打开。

3. 导出 Word 文件(.docx)

仅需修改 Blob 的 type 和文件名后缀,核心逻辑完全一致:

go 复制代码
// 新版 文件格式.docx
    const blob = new Blob([response.data], {
      type: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' // Word MIME类型
    });
    
// 旧版 文件格式.doc
const blob = new Blob([response.data], {
      type: 'application/msword' 
    });

  

4. 导出 PDF 文件(.pdf)

go 复制代码
    // 创建 Blob,指定 PDF 类型
    const blob = new Blob([response.data], {
      type: 'application/pdf'
    });
相关推荐
升鲜宝供应链及收银系统源代码服务6 小时前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
i建模6 小时前
将Edge浏览器的标签页从顶部水平排列**移至左侧垂直侧边栏
前端·edge
跟着珅聪学java6 小时前
js编写中文转unicode 教程
前端·javascript·数据库
英俊潇洒美少年7 小时前
Vue3 深入响应式系统
前端·javascript·vue.js
颜酱7 小时前
回溯算法实战练习(3)
javascript·后端·算法
英俊潇洒美少年8 小时前
React 最核心 3 大底层原理:Fiber + Diff + 事件系统
前端·react.js·前端框架
我命由我123458 小时前
React Router 6 - 概述、基础路由、重定向、NavLink、路由表
前端·javascript·react.js·前端框架·ecmascript·html5·js
LJianK18 小时前
java封装
java·前端·数据库
yaaakaaang8 小时前
(四)前端,如此简单!---Promise
前端·javascript
aini_lovee9 小时前
C# 实现邮件发送源码(支持附件)
开发语言·javascript·c#