angular中下载接口返回文件

目录

一、URL.createObjectURL()

一、URL.createObjectURL()

createObjectURL属于js的原生方法,位于window.URL上,用于将Blob或者File文件转换为可以临时的URL地址进行显示

**注意**:Angular 的 HttpClient 默认将响应解析为 JSON 对象‌16。若实际返回的是二进制数据(如 Excel 文件、图片等),解析过程会因格式不匹配抛出错误(如 Unexpected token[object Object]

TypeScript 复制代码
//首先调接口,subscribe接收一个可观察对象,
//有三个可选函数,next为成功时的函数,此时返回的二进制文件,
//包含size和type两个属性,使用createObjectURL将二进制文件转换为url地址,
//再创建a标签,实现自动下载返回的文件,最后需要释放创建的地址(生成的 URL 会占用内存,需手动释放以避免泄漏)
//error为出错时所调函数       
this.service.importExcel(formData).subscribe({
                next: (blob: Blob) => {
                    console.log(blob);
                     if (blob.size > 0 && blob.type.startsWith('application/')) {
                         const url = window.URL.createObjectURL(blob);
                         const link = document.createElement('a');
                         link.href = url;
                         link.download = '导入人员信息.xlsx'; // 自定义文件名
                         link.click();
                        window.URL.revokeObjectURL(url); // 释放内存
                     }
                },
                error: (error: any) => {
                    this.message.warning('文件异常');
                },
            });

//需要将接口的响应数据改为Blob二进制文件,使用responseType修改响应数据类型为Blob
 importExcel(params) {
        const url = 'api/xxx';
        return this.http.post(url, params, {
            responseType: 'blob',//有时候会报错则使用'blob' as 'json'
        });
    }
相关推荐
长袖格子衫14 分钟前
第五节:对象与原型链:JavaScript 的“类”与“继承”
开发语言·javascript·原型模式
咖啡の猫15 分钟前
JavaScript基础-全局作用域
开发语言·javascript
GISer_Jing20 分钟前
前端性能优化全攻略:从基础体验到首屏加载的深度实践
前端·javascript·性能优化
pink大呲花21 分钟前
深入理解 Vue 全局导航守卫:分类、作用与参数详解
前端·javascript·vue.js
xixixiLucky1 小时前
配置Java Selenium Web自动化测试环境
java·前端·selenium
gregmankiw1 小时前
第二个简单的SpringBoot和Vue前后端全栈的todoapp案例
前端·javascript·vue.js
酷小洋2 小时前
Ajax基础
前端·ajax·okhttp
小妖6662 小时前
vue2 provide 后 inject 数据不是响应式的,不实时更新
java·服务器·前端
是代码侠呀2 小时前
HTTP 的发展史:从前端视角看网络协议的演进
前端·网络协议·http·开源·github·github star·github 加星
heyCHEEMS3 小时前
Vue 两种导航方式
前端·javascript·vue.js