当前位置: 首页 > article >正文

angular中下载接口返回文件

目录

一、URL.createObjectURL()

一、URL.createObjectURL()

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

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

//首先调接口,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'
        });
    }


http://www.kler.cn/a/583423.html

相关文章:

  • 大一新生备战蓝桥杯c/c++B组——2024年省赛真题解题+心得分享
  • 可编辑PPT解析数字化转型是什么意思,传统企业的数字化、数字转型数字化变革之路
  • c语言中的未定义行为
  • Python从基础开发到前沿技术完整生态(应用技术栈)(2025版)
  • 隐藏的git文件夹
  • Linux - 磁盘分区、挂载
  • Springboot redis bitMap实现用户签到以及统计,保姆级教程
  • MongoDB分页实现方式对比:PageRequest vs Skip/Limit
  • Ubuntu-配置apt国内源
  • 暴力破解Excel受保护的单元格密码
  • 数据批处理(队列方式)
  • QT系列教程(13) 事件系统
  • linux学习(十二)(联网(TCP/IP堆栈,子网掩码,以太网arp/rarp,DHCP,IP路由,DNS解析,网络过滤器,SSH公司,文件传输))
  • 在类似于Manus的项目中,我想使用python控制用户的浏览器,我应该选择selenium呢?还是playwright?
  • ubuntu22.04 关于挂在设备为nfts文件格式无法创建软连接的问题
  • 4-文件导入功能文档
  • 基于Redis实现限流
  • 蓝桥杯第三天:2023蓝桥杯省赛 第 1 题
  • Django系列教程(4)——实例项目任务管理小应用
  • 链上权益:基于区块链技术的数字版权管理革命