前端下载文件有哪些方式

news/2024/7/19 12:55:24 标签: 前端, js

前端下载文件有哪些方式

前端,最常见和最常用的文件下载方式是:

  1. 使用 标签的 download 属性:

创建一个 标签,并设置其 href 属性为文件的 URL,然后使用 download 属性指定下载的文件名。
这种方式简单直接,适用于下载单个文件,例如图片、文档、音频或视频等。

  1. window.open(imageUrl, ‘_blank’)
    window.open 方法可以在新的浏览器窗口或标签页中打开指定的 URL。通过将文件的 URL 传递给 window.open 方法,并指定第二个参数为 _blank,可以在新的标签页中打开文件,并触发浏览器的文件下载行为

window.open 方法可能会受到浏览器的弹出窗口阻止设置的影响,因此在某些情况下,浏览器可能会阻止弹出新的标签页。此外,该方式无法自定义下载文件名或其他下载选项。

  1. 使用 fetch API:
    使用 fetch 方法发送 GET 请求获取文件数据,然后使用 Response.blob() 方法将响应数据转换为 Blob 对象。
    创建一个链接或 Blob 对象,并使用 URL.createObjectURL 方法生成一个临时链接,最后模拟点击下载。
    这种方式适用于需要在下载前进行更多处理的情况,例如添加请求头、验证、处理错误等,以及需要动态生成下载内容的场景。

不同的下载方式适用于不同的场景

  1. window.open 方法:
  • 适用于直接在浏览器中打开文件或以新窗口或标签页的形式显示文件内容。
  • 适用于非敏感、公开的文件下载,例如图片、PDF 文件等。
  • 不适用于需要自定义下载文件名或其他下载选项的场景。
  1. 标签的 download 属性:
  • 适用于直接在浏览器中下载文件,提供了简单的方式指定下载文件的名称。
  • 适用于单个文件的下载,例如图片、文档、音频或视频文件等。
  1. 使用 Fetch API 和 Axios :
  • 适用于需要在前端进行更多处理的下载操作,例如在下载前需要添加请求头、验证、处理错误等。
  • 适用于需要动态生成下载内容的场景,例如将多个文件合并为一个压缩文件或生成动态报表等。
  • 提供更多的灵活性和控制能力,但可能需要更多的代码和处理逻辑。

Fetch API 是原生的 JavaScript API,提供了一种简单、基础的方式来发送和处理网络请求。它是现代浏览器原生支持的一种方法。

而 Axios 是一个流行的第三方库,提供了更高级、更易用的 API,用于发送 HTTP 请求。Axios 具有更多的功能和配置选项,并且能够在不同的环境中使用(包括浏览器和 Node.js)。

总结:如果只是简单地下载一个单独的文件,并且不需要进行额外的处理或自定义,那么使用 标签的 download 属性或 window.open 方法是最简单和直接的方式。如果需要更多的控制和处理能力,或者需要动态生成下载内容,那么使用 fetch API 可能更适合。

使用Axios 下载文件举例

  const handleDownload = (imageUrl: string) => {
    let token = localStorage.getItem('token');
    if (null === token) {
        token = '';
    }

    
    axios({
      url: imageUrl,
      method: 'GET',
      responseType: 'blob', // 设置响应类型为 blob
      headers: {
        Authorization: `Bearer ${token}`,  // 替换为您的 Bearer Token
      },
    })
      .then((response) => {
        const url = URL.createObjectURL(new Blob([response.data]));
  
        const link = document.createElement('a');
        link.href = url;
        link.download = 'filename.jpg'; // 设置下载的文件名
        link.click();
  
        URL.revokeObjectURL(url);
      })
      .catch((error) => {
        console.error('Error downloading file:', error);
      });
  };

http://www.niftyadmin.cn/n/5368937.html

相关文章

Flume拦截器使用-实现分表、解决零点漂移等

1.场景分析 使用flume做数据传输时,可能遇到将一个数据流中的多张表分别保存到各自位置的问题,同时由于采集时间和数据实际发生时间存在差异,因此需要根据数据实际发生时间进行分区保存。 鉴于此,需要设计flume拦截器配置conf文件…

【SQL高频基础题】610.判断三角形

题目: 表: Triangle ------------------- | Column Name | Type | ------------------- | x | int | | y | int | | z | int | ------------------- 在 SQL 中,(x, y, z)是该表的主键列。 该表的每一行包含三个线段的…

即席查询框架怎么选?

怎么理解即席查询 即席查询(Ad Hoc)是用户根据自己的需求,灵活的选择查询条件,系统能够根据用户的选择生成相应的统计报表。即席查询与普通应用查询最大的不同是普通的应用查询是定制开发的,而即席查询是由用户自定义查…

C++的缺省参数和函数重载

目录 1.缺省参数 1.1缺省参数的概念 1.2缺省参数的分类 1.3缺省参数使用场景 2.函数重载 2.1函数重载的概念 2.2构成函数重载 1.缺省参数 1.1缺省参数的概念 概念:缺省参数是声明或定义函数时为函数的参数指定一个缺省值。在调用该函数时,如果没…

代码随想录算法训练营29期|day43 任务以及具体任务

第九章 动态规划 part05 1049. 最后一块石头的重量 II class Solution {public int lastStoneWeightII(int[] stones) {int sum 0;for (int i : stones) {sum i;}int target sum >> 1;//初始化dp数组int[] dp new int[target 1];for (int i 0; i < stones.lengt…

对接快团团,如何快速高效对接快团团大团长?

如何快速高效对接快团团大团长&#xff1f; 快团团的团长&#xff0c;对于大多数品牌来说&#xff0c;找到他们很容易&#xff08;ps&#xff1a;需要团长的联系方式&#xff0c;私聊我&#xff0c;&#xff09;&#xff0c;建联不容易&#xff0c;合作更加不容易。 因为快团…

博客|基于Springboot的个人博客系统设计与实现(源码+数据库+文档)

个人博客系统目录 目录 基于Springboot的个人博客系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员功能实现 &#xff08;1&#xff09;用户管理 &#xff08;2&#xff09;文章分类管理 &#xff08;3&#xff09;公告信息管理 &#xff08;4&#…

c# List集合操作帮助类

public class ListHelper { #region 赋值转换 /// <summary> /// A实体转换成B实体 /// </summary> /// <typeparam name"T"></typeparam> /// <typeparam name"K"></typep…