后端返回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";
    },

相关推荐
于慨17 小时前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz17 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶17 小时前
前端交互规范(Web 端)
前端
CHU72903517 小时前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing17 小时前
Page-agent MCP结构
前端·人工智能
王霸天17 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航17 小时前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界17 小时前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc17 小时前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说18 小时前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js