后端返回Blob文件流,前端实现导出

  1. 拦截器修改

    // 检查响应是否为blob类型
    if (response.data instanceof Blob) {
    return response;
    } else {
    // 正常对象
    if (res.returnCode == 200) {
    return res;
    } else {
    // 错处理
    }
    }

  2. 接口处理,返回数据类型设置为 responseType: "blob"

3.导出函数

复制代码
// 导出
    output() {
      let data = {};
      if (this.status) {
        data.status = this.status * 1;
      }
      downExcel(data).then((response) => {
        const disposition = response.headers["content-disposition"];
        let filename = this.parseFilenameFromDisposition(disposition);
        this.$message({
          message: "导出成功!",
          type: "success",
        });
        // 创建 Blob 对象
        const blob = new Blob([response.data]);
        // 创建下载链接
        const url = window.URL.createObjectURL(blob);
        const link = document.createElement("a");
        link.href = url;
        link.setAttribute("download", filename); // 设置下载文件名
        document.body.appendChild(link);
        link.click();
        // 清理DOM和对象URL
        document.body.removeChild(link);
        window.URL.revokeObjectURL(url);
      });
    },
  1. 解析后端在content-disposition中返回的文件名称

    parseFilenameFromDisposition(contentDisposition) {
    if (!contentDisposition) {
    return "download";
    }
    const filenameRegex =
    /(?:filename|fileName)[;=\n]*=((['"]).*?\2|[;\n]*)/;
    const matches = filenameRegex.exec(contentDisposition);
    if (matches && matches[1]) {
    // 提取文件名并去除引号
    let filename = matches[1].replace(/['"]/g, "");
    // 尝试解码URL编码的文件名
    try {
    filename = decodeURIComponent(filename);
    } catch (e) {
    console.warn("文件名解码失败:", e);
    }
    return filename;
    }
    return "download";
    },

相关推荐
锋行天下41 分钟前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架
光影少年1 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
禅思院3 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮4 小时前
深入理解Loop Engineering
前端·后端
风骏时光牛马4 小时前
VHDL十大经典基础功能设计实例代码合集
前端
hunterandroid4 小时前
Notification 通知:从基础到渠道适配
前端
孟陬4 小时前
Claude Code 巧思 `Ctrl+S` 暂存键
前端·后端
PedroQue994 小时前
V1.6.1性能优化:高频路径提速与代码精简
前端·uni-app
猩猩程序员5 小时前
将 LiteLLM 迁移到 Rust —— 构建最快、最轻量的 AI Gateway
前端
lichenyang4535 小时前
JSBridge 分发升级:为什么要从 if-else 变成 Registry > 这是「ASCF 架构升级」系列的第 3 篇
前端