vue 处理二进制文件流下载,封装请求

后端返回的文件流

前端需要处理成下载文件

刚开始一直报错

处理的方法

复制代码
// http.js
import instance from './axios';

export const get = (url, params = {}, config = {}) => instance.get(url, { params, ...config });

// api.js
/**
 * 获取下载错误信息
 * @param {string} batchId - 批次ID
 * @returns {Promise} - 返回一个Promise对象,用于异步获取服务器响应
 */
export const downloadErrorMessage = (batchId, config = {}) => {
  return get(`/admin/finance/enterprise-authorization/downloadErrorMessage/${batchId}`, {}, config);
};

重点就是config配置 responseType: 'blob'

页面代码

复制代码
  downloadErrorMessage(res.data.batchId, { responseType: 'blob' }).then((response) => {
                  // 处理二进制数据并创建 Blob 对象
                  const blobObj = new Blob([response.data], {
                    'content-type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8',
                  });
                  saveAs(blobObj, 'error.xls'); // 这个是用的插件,不用插件可以自己创建a标签
                  handleClose();
                  emits('init');
                });

插件使用

使用 npm 安装 FileSaver.js:

复制代码
npm install file-saver --save

页面引入

复制代码
import { saveAs } from 'file-saver';

不用插件可以用a标签代替

相关推荐
玄玄子1 分钟前
webpack学习指南
前端·webpack·程序员
不爱说话郭德纲2 分钟前
面试官:你给我讲讲async/await
前端·深度学习·面试
前端小巷子3 分钟前
Promise 链式调用:让异步编程更优雅
前端·面试·promise
周日不上发条4 分钟前
前端必学:CSS实现精美渐变色票据组件(含完整源码)
前端
有梦想的攻城狮10 分钟前
从0开始学vue:pnpm怎么安装
前端·javascript·vue.js
pzpcxy52013 分钟前
安装VUE客户端@vue/cli报错警告npm WARN deprecated解决方法 无法将“vue”项识别为 cmdlet、函数
前端·vue.js·npm
醉书生ꦿ℘゜এ13 分钟前
npm error Cannot read properties of null (reading ‘matches‘)
前端·npm·node.js
疯狂的沙粒28 分钟前
uni-app 如何实现选择和上传非图像、视频文件?
前端·javascript·uni-app
娃哈哈哈哈呀30 分钟前
html-pre标签
java·前端·html
$程31 分钟前
Uniapp 二维码生成与解析完整教程
前端·uni-app