前端如何下载后端传输的文件

前端下载后端传回的文件有三种方式

  1. 直接打开下载地址:这种无法命名,只适用于get直接返回blob的接口
  2. 利用a标签的download:这种是比较适合的方案
  3. file-saver:这是现成的库,简单方便

几个重要概念

createObjectURL :把blob对象的内存地址,以url形式给出

msSaveBlob : IE不支持a标签下载,用的是msSaveBlob方案

a标签的download属性 : 表面该a标签的行为是下载,并说明文件名

javascript 复制代码
//按blob请求接口   
// 这边响应必须设置成blob类型
axios.get('http://localhost:8000/download',{responseType:'blob'}).then((res) => {
    console.log(res.data)
    if(window.navigator.msSaveBlob){
        //说明是IE浏览器,需要做兼容
        window.navigator.msSaveBlob(res.data,{type:'application/xxxxxx'},"test.ppt")
    } else {
        //说明是现代主流浏览器 
        //传入文件数据,生成一个 下载链接
        let blobURL = URL.createObjectURL(res.data)
        //创建标签
        let link = document.createElement('a')
        //设置href
        link.href = blobURL 
        //设置a标签的行为是download,不然就跳转了,同时设置名字是"test.ppt"
        link.download = "test.ppt"
        //隐藏a标签,他只是下载,没必要出现
        link.style.display = "none"
        //模拟点击
        link.click()
        //最后,把这个URL进行销毁,免得他占内存
        URL.revokeObjectURL()
             
    }
})

//使用第三方库file-saver

javascript 复制代码
//引入第三方库
import {saveAs} from "file-saver"

axios.get('http://xxxxxxxxxxx',{responseType:'blob'}).then((res) => {
    saveAs(res.data,"fileSaveDownload.ppt")
})
	
相关推荐
by__csdn29 分钟前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
天天扭码44 分钟前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
Luna-player1 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
lionliu05191 小时前
js的扩展运算符的理解
前端·javascript·vue.js
小草cys2 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript
奇舞精选2 小时前
GELab-Zero 技术解析:当豆包联手中兴,开源界如何守住端侧 AI 的“最后防线”?
前端·aigc
奇舞精选2 小时前
Vercel AI SDK:构建现代 Web AI 应用指南
前端·aigc
神仙别闹2 小时前
基于C语言实现B树存储的图书管理系统
c语言·前端·b树
玄魂3 小时前
如何查看、生成 github 开源项目star 图表
前端·开源·echarts
前端一小卒3 小时前
一个看似“送分”的需求为何翻车?——前端状态机实战指南
前端·javascript·面试