Malunan个人博客|IT技术博客 Malunan个人博客|IT技术博客
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Lunan Ma

升职加薪搞钱~
首页
  • 前端文章

    • JavaScript
  • 学习笔记

    • 《JavaScript教程》
    • 《JavaScript高级程序设计》
    • 《ES6 教程》
    • 《Vue》
    • 《React》
    • 《TypeScript 从零实现 axios》
    • 《Git》
    • TypeScript
    • JS设计模式总结
    • HTML
    • CSS
  • 技术文档
  • GitHub技巧
  • Nodejs
  • 博客搭建
  • 脚本
  • 剪辑
关于
  • 网站
  • 常用的前端轮子
  • 工具网站
  • 软件工具
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 技术文档

    • Git使用手册
    • Markdown使用教程
    • npm常用命令
    • 移动端兼容问题
    • 常用cmd命令
    • npm packageJson属性详解
    • yaml语言教程
    • Git修改分支名
    • javaScript-时间相加,超过24小时继续累加
    • 获取视频文件第一帧
    • 前端获取文件下载进度
    • 前端获取上传的视频图片详细信息
    • 解决拖拽时,如果元素内有input,无法选中文本的问题
    • css点击穿透
    • vue插槽传参
    • 谷歌浏览器的kiosk模式
    • 前台下载后台返的二进制文件流
      • 需求
      • 实现
    • css实现无缝切换跑马灯样式
    • 前端优化规范
    • 懒加载+无感删除list思路
  • GitHub技巧

  • Nodejs

  • 博客搭建

  • 脚本

  • 技术
  • 技术文档
MaLunan
2024-03-05
目录

前台下载后台返的二进制文件流

# 需求

前端下载文件,发起请求,后端返回二进制流

# 实现

  • 考虑到项目中可能涉及多处下载,所以进行axios统一拦截

//axios 拦截器添加判断

 /// response 响应拦截 查看请求头是否为blob类型
 response => {
 if(response.config && response.config.responseType == 'blob') {
//type内写请求头的类型
        const blob = new Blob([response.data], { type: 'application/octet-stream;charset=utf-8' }); //application/vnd.openxmlformats-officedocument.spreadsheetml.sheet这里表示xlsx类型
        let filename = decodeURI(response.headers['filename']);
        if ('download' in document.createElement('a')) {
            const downloadElement = document.createElement('a');
            let href = '';
            if(window.URL) href = window.URL.createObjectURL(blob);
            else href = window.webkitURL.createObjectURL(blob);
           downloadElement.href = href;
           downloadElement.download = filename;
           document.body.appendChild(downloadElement);
           downloadElement.click();
           if(window.URL) window.URL.revokeObjectURL(href);
            else window.webkitURL.revokeObjectURL(href);
            document.body.removeChild(downloadElement);
        } else {
            navigator.msSaveBlob(blob, filename);
        }
        return;
    }
  }
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
编辑 (opens new window)
上次更新: 2024/03/06, 09:47:28
谷歌浏览器的kiosk模式
css实现无缝切换跑马灯样式

← 谷歌浏览器的kiosk模式 css实现无缝切换跑马灯样式→

最近更新
01
懒加载+无感删除list思路
11-12
02
移动端兼容问题
11-12
03
前端优化规范
03-25
更多文章>
Theme by Vdoing | Copyright © 2019-2024 LuNan Ma | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式