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

前端下载文件的方法-blob下载

前端经常会遇到下载文件的需求,后端一般提供的以下两种方法:

  • 文件地址。后端直接提供要下载的文件地址,常用于图片、音视频等静态文件
  • 文件流。后端返回文件流,常用于excel等动态文件

一、a 标签下载

1、直接html使用a标签下载
  • href:文件链接
  • download:下载时的文件名称,相当于重命名了,可以不设置该属性
<a href="https://example.com/images/a.png" download="b.png">下载</a>
2、通过js方法借用a标签下载
downloadFile(fileurl) {
    let a = document.createElement('a')   // 创建一个a标签
    a.href = fileurl                      // 赋值链接
    a.style.display = 'none'              // 隐藏,设置元素不可见
    document.body.appendChild(a)          // 添加a到页面
    a.click()                             // 模拟点击,进行跳转或下载操作
    document.body.removeChild(a)          // 操作完成,移除a
}

二、window 下载

1、window.location.href
downloadFile(fileurl) {
    window.location.href = fileurl
}
2、window.open
downloadFile(fileurl) {
    window.open(fileurl)
}

注: window.open() 可能会被浏览器拦截器屏蔽,而 window.location.href 不会受到影响

三、blob下载流文件

1、引入axios

import axios from 'axios'

2、blob下载

downloadFile() {
    // 文件地址,可携带参数
    const fileurl = `/file/example/excel/abc?id=${this.id}&appId=${this.appId}`
    // 请求并下载文件,可设置 headers
    axios
       .get(fileurl, {
           responseType: 'blob', // 必须,指定响应的数据类型为二进制数据流(Blob对象)
           headers: {
              'X-Auto-Fp-Plate': 'example',
           },
        })
        .then(response => {
            let url = window.URL.createObjectURL(response.data) // 将二进制文件转化为可访问的url
            let a = document.createElement('a')
            a.href = url
            a.style.display = 'none'
            document.body.appendChild(a)
            // 一般在响应头的 content-disposition 里设置文件名称,下面是提取文件名示例
            const arr = response.headers['content-disposition'].split('filename=')
            const fileName = decodeURI(arr[arr.length - 1])
            a.download = fileName  // 将获取的文件名赋值过去,也可自行赋值
            a.click()
            document.body.removeChild(a)
            window.URL.revokeObjectURL(url) // 释放url
        })
        .catch(error => {
            // do something
        })
    },

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

相关文章:

  • 蓝桥与力扣刷题(709 转换成小写字母)
  • 集合帖:区间问题
  • vue3 uiapp实现一个数字输入组件, 舒服非数字会默认转成最小数
  • 浅谈ArcGIS的地理处理(GP)服务之历史、现状和未来
  • W25Q64-FLASH
  • LabVIEW智能水肥一体灌溉控制系统
  • LLM推理部署(五):AirLLM使用4G显存即可在70B大模型上进行推理
  • Prime 2.0
  • 基于maobox-gl 纯前端绘制全球色斑图
  • 布局问题1:addSpacing()和setSpacing()函数的区别?
  • C++服务器 支持http、tcp protobuf、websocket,linux开源框架 零依赖轻松编译部署 Reactor
  • nodejs实现文件/目录的压缩和解压
  • 【微信小程序】上传头像 微信小程序内接小程序客服
  • C++ day51 买卖股票最佳时期
  • 计算机网络——习题
  • 【PTA-C语言】编程练习3 - 循环结构Ⅱ
  • 安装配置JDK1.8
  • 单例模式的实现
  • 字符串转换整数
  • 一个完整的手工构建的cuda动态链接库工程 03记
  • SQL Server 2016(创建数据表)
  • qt-C++笔记之识别点击鼠标右键、点击位置以及Qt坐标系详解
  • flutter-web中使用js工具类
  • Linux系统配置深度学习环境之cudnn安装
  • 40 mysql join 的实现
  • jmeter下载地址