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

相关推荐
wuhen_n2 小时前
TypeScript的对象类型:interface vs type
前端·javascript·typescript
lindd9119112 小时前
4G模块应用,内网穿透,前端网页的制作第七讲(智能头盔数据上传至网页端)
前端·后端·零基础·rt-thread·实时操作系统·项目复刻
css趣多多2 小时前
props,data函数,computed执行顺序
前端·javascript·vue.js
一个不称职的程序猿2 小时前
构建优雅的 Vue.js 表情包选择器:一个功能丰富且可定制的 Emoji Picker 组件
前端·javascript·vue.js
Charlie_lll2 小时前
学习Three.js--光源Light+轨道控制器OrbitControls
前端·three.js
Amumu121382 小时前
Vue核心(二)
前端·javascript·vue.js
墨轩尘3 小时前
qiankun的简单使用
前端·vue.js·前端框架
EEEzhenliang3 小时前
CSS样式所有使用方式(书写位置)
前端·css
愚公移码3 小时前
蓝凌EKP产品:关联机制浅析
java·服务器·前端