前端批量下载文件(干货)

news2024/11/26 9:32:52

如果可以实现记得点赞分享,谢谢老铁~

1.常见的下载方式

(1) window.open()
(2) 通过 标签绑定url
(3) 通过请求后台API接口进行下载

2.推荐方式

(1)如果是下载单个文件的

直接用window.open(url, ‘打开方式’)
这里的打开方式常用的是当前窗口 :“self " 或者是重新新开一个窗口:”_blank"。
下载的话通常在当前窗口打开。

(2)如果是批量下载

拼接url利用window.open下载多个文件时,window.open会中断循环。所以不能使用window.open();
但可以使用循环生成iframe方法实现批量下载。

// 可以使用循环生成iframe方法实现批量下载
const iframe = document.createElement("iframe");
iframe.style.display = "none"; // 不可见
iframe.style.height = "0"; // 高度为0
iframe.src = url; // 下载地址
document.body.appendChild(iframe); // 必须有,iframe挂在到dom树触发请求

3.先看场景图

在这里插入图片描述

4.实现代码

html文件
这里点击下载给它一个loading效果。

 <Button
   size="small"
   type="primary"
   onClick={requestForEachByDown}
   loading={btnLoad}
 >
   下载
 </Button>
 

ts文件

  const [btnLoad, setBtnLoad] = useState(false); // 下载loading
  const [selectedUrls, setSelectedUrls] = useState([]);// 批量勾选的下载地址集合
  // 遍历请求下载
  const requestForEachByDown = () => {
    setBtnLoad(true)
    const proArr = [] // 多个Promise实例
    if (selectedUrls?.length > 0) {
      selectedUrls.forEach((url, index) => {
        proArr[index] = new Promise((resolve) => {
          getAPI({ url }).then((res) => {
            resolve(res)
          })
        })
      })
      Promise.all(proArr).then((resArr) => {
        if (resArr?.length > 0) {
          resArr?.forEach((item) => {
            setBtnLoad(false)
            // 可以使用循环生成iframe方法实现批量下载
            const iframe = document.createElement("iframe");
            iframe.style.display = "none"; // 不可见
            iframe.style.height = "0"; // 高度为0
            iframe.src = item?.data?.url; // 下载地址
            document.body.appendChild(iframe); // 必须有,iframe挂在到dom树触发请求

            //window.open下载文件下载多个文件时,window.open会中断循环。
            // window.open(item?.data?.url, '_self');

          })
        }
      })
    }
  }

PS:请注意浏览器对URL的长度限制,尤其是银行政府类的项目,下载通过get请求下载的多加注意!!!

  1. IE浏览器对URL的长度现限制为2048字节。
  2. 360极速浏览器对URL的长度限制为2118字节。
  3. Firefox(Browser)对URL的长度限制为65536字节。
  4. Safari(Browser)对URL的长度限制为80000字节。
  5. Opera(Browser)对URL的长度限制为190000字节。
  6. Google(chrome)对URL的长度限制为8182字节。

收工!谢谢老铁们的点赞收藏~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1188745.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Git 分支设计规范

开篇 这篇文章分享 Git 分支设计规范&#xff0c;目的是提供给研发人员做参考。 规范是死的&#xff0c;人是活的&#xff0c;希望自己定的规范&#xff0c;不要被打脸。 在说 Git 分支规范之前&#xff0c;先说下在系统开发过程中常用的环境。 DEV 环境&#xff1a;用于开发…

rtklib的rtknavi使用

1、点击rtknavi工具 2、配置输入的数据流 采用香港基准站的实时数据流&#xff0c;进行验证。 输入caster的地址 landsd-gncaster.realtime.data.gov.hk 选择HKSS 和HKWS 配置Options 点击运行

2023亚太杯数学建模A题B题C题思路汇总分析

文章目录 0 赛题思路1 竞赛信息2 竞赛时间3 建模常见问题类型3.1 分类问题3.2 优化问题3.3 预测问题3.4 评价问题 4 建模资料5 最后 0 赛题思路 &#xff08;赛题出来以后第一时间在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 1 竞赛信息 2023年第十三…

[黑马程序员Pandas教程]——合并与变形

目录&#xff1a; 学习目标Dataframe合并 df.append函数纵向追加合并dfpd.concat函数纵向横向连接多个数据集df.merge合并指定关联列的多个数据集df.join横向合并索引值相同的多个数据集df合并小结Dataframe变形 df.T行列转置df.stack()和s.unstack()变形df.melt宽变长将列名变…

企业该怎么选择泛域名https证书

随着互联网技术的不断进步&#xff0c;网络安全技术也在不断发展&#xff0c;https数字证书技术也在不断进步。现在&#xff0c;为了迎合市场需求&#xff0c;CA认证机构开发了多种类型的https数字证书&#xff0c;而泛域名https证书可以有效地保护多个网站客户的个人隐私和信息…

通信原理板块——图像压缩编码

微信公众号上线&#xff0c;搜索公众号小灰灰的FPGA,关注可获取相关源码&#xff0c;定期更新有关FPGA的项目以及开源项目源码&#xff0c;包括但不限于各类检测芯片驱动、低速接口驱动、高速接口驱动、数据信号处理、图像处理以及AXI总线等 1、图像压缩编码 图像压缩编码可以…

增强group by的使用

-- (1) 显示某种岗位的雇员总数、平均工资 SELECT COUNT(empno),FORMAT(AVG(sal),2) AS avg_sal,jobFROM empGROUP BY job; -- (2) 显示雇员总数&#xff0c;以及获得补助的雇员数 SELECT COUNT(*) AS emp_total,COUNT(comm) AS emonyFROM emp;-- (3) 统计获得补助的非空补助的…

中国人民大学与加拿大女王大学金融硕士——在金融领域里持续探索、成长

在金融领域里持续探索、成长&#xff0c;这是一个永无止境的旅程。在这个领域里&#xff0c;机遇与挑战并存&#xff0c;未知与已知交织&#xff0c;需要我们时刻保持敏锐的洞察力和扎实的基本功。金融市场的变化日新月异&#xff0c;我们需要时刻关注市场动态&#xff0c;了解…

腾讯待办是不是停了?怎么用其它提醒软件查看导出的ics文件

腾讯待办是腾讯企业旗下的业务产品&#xff0c;其主要以微信小程序的形式使用&#xff0c;定位于待办事项和日程管理工具&#xff0c;支持罗列日程待办清单、设定定时提醒&#xff0c;帮助大家规划日常事务和进行时间管理&#xff0c;成功创建待办事项后可在对应的公众号和绑定…

餐品展示订餐小程序的作用是什么

对有门店的餐饮商家来说&#xff0c;只要味道能说的过去&#xff0c;能够满足时间、空间需求&#xff0c;那么订餐就会很平常&#xff0c;对中型或酒店等单位更是趋于平常&#xff0c;同时还有订桌、菜品预约、咨询等需求&#xff0c;那么对餐饮商家来说&#xff0c;基于餐品展…

互联网常见职称

1、管理层 CEO – Chief Executive Officer 首席执行官 VP – Vice President 副总裁 HRD – Humen Resource Director 人力资源总监 OD – Operations Director 运营总监 MD – Marketing Director 市场总监 GM – General Manager 总经理 PM – Production Manager 产品…

新能源产业微电网保护及安全自动装置解读

安科瑞 崔丽洁 摘 要&#xff1a;在“碳达峰”、“碳中和”的双碳背景下&#xff0c;为了避免化石能源的直接燃烧导致气候变化&#xff0c;新能源将作为新型电力系统供电的主体。为了保证新型电力系统的可靠运行&#xff0c;配置微机保护装置和电能质量在线监测装置有效监测电…

Flat Ads凭全球6亿独家流量,入选《中国数字营销生态图2023版》名单

近日&#xff0c;中国商务广告协会数字营销专业委员会、虎啸奖组委会、秒针营销科学院共同发布了《中国数字营销生态图&#xff08;2023版&#xff09;》的入选名单。该图谱一共包含三大类19个大赛道&#xff0c;109个细分赛道&#xff0c;收录了千余家数字营销优质服务商、媒体…

管理视频推广工作:新媒体团队的成功策略

目前的新媒体团队&#xff0c;在视频管理时呈现出多、杂、散的特点&#xff0c;如何有效管理视频素材是当下许多新媒体团队的管理痛点&#xff0c;也是管理要点。高效的视频推广管理是新媒体团队提升产出效率的关键。 那么新媒体行业该如何管理视频推广工作&#xff1f; 数据…

[SUCTF 2019]CheckIn1

提示 一句话木马的多种变式(这里需要用到用javascript来写一句话木马)注意修改文件头 先随意上传一个文件fuzz一下看能不能直接传webshell 从下面来看常见php后缀都不行&#xff0c;其中有一个没有加后缀过了后缀验证这一步&#xff0c;到了下一步&#xff0c;但是他还会看文件…

Java关于由子类构造器生成的父类对象的反射问题

Java关于由子类构造器生成的父类对象的反射问题 问题概括一、案例准备二、问题描述 问题概括 提示&#xff1a;这里我就不绕圈子直接描述&#xff1a; Java中由子类构造器生成的父类的getclass.getName不是父类的类名而是子类的类名&#xff0c;因此不可以用子类构造器生成的…

环形链表I和II

环形链表I 题目描述 给你一个链表的头节点 head &#xff0c;判断链表中是否有环。如果链表中存在环&#xff0c;则返回true。否则&#xff0c;返回false 。 解题思路 采用快慢指针的思想&#xff0c;创建fast和slow一快一慢指针&#xff0c;slow一次走一步&#xff0c;fas…

Flutter StreamBuilder 实现局部刷新 Widget

Stream 就是事件流或者管道&#xff0c;是基于事件流驱动设计代码&#xff0c;然后监听订阅事件&#xff0c;并针对事件变换处理响应。 Stream 分单订阅流和广播流,单订阅流在发送完成事件之前只允许设置一个监听器&#xff0c;并且只有在流上设置监听器后才开始产生事件&…

antd Form 校验自定义复杂判断-validator

antd Form 校验 加入自定义复杂逻辑 <Form.Itemlabel"编码"name"code"rules{[{required: true,validator: (_rule, value) > {if (value ) {return Promise.reject(请输入编码);}return IsExist(value).then((res) > {if (res?.statusCode 20…

【Git系列】Github指令搜索

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…