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

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

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字节。

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

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux文件查找与压缩干货 云计算干货 Linux系统配置及服务管理文件查找 文件查找 简介 which :命令查找 find: 文件查找,针对文件名 locate:文件查找,依赖数据库 一、命令文件查找 一、查找ls 命令的位置 # which ls //从PATH环境变量 或者 # whereis vim 二、任意文件 find 语法 find [path...] [options] [expression] [action] 命令 路径 选项 表达式 动作 ①按文件名: [root@qianfeng ~]# find /etc -name "hosts" [root@qianfeng ~]# find /etc -iname "hosts" find /etc -iname "HOSTS" -i忽略大小写 i可以忽略大小写来查找 [root@qianfeng ~]# find /etc -iname "hos*" 心中有爱(i),什么都找得到 结果输出 /etc/hosts 文件查找成功 ②按文件大小: [root@qianfeng ~]# find /etc -size +5M 文件>5M 这里“size”是大小意思 [root@qianfeng ~]# find /etc -size 5M 文件=5M [root@qianfeng ~]# find /etc -size -5M 文件<5M ③指定查找的目录深度: [root@qianfeng ~]# find / -maxdepth 3 -a -name "ifcfg-en*" 这里maxdepth是深度 后面的数字是几级目录 [root@qianfeng ~]# find / -maxdepth 4 -a -name "ifcfg-en*" ④按文件属主、属组找: [root@qianfeng ~]# find /home -user aaa // 属主是aaa的文件 [root@qianfeng ~]# find /home -group hr // 属组是hr组的文件 ⑤按文件类型: [root@qianfeng ~]# find /tmp -type f f普通文件 文件type关键词 [root@qianfeng ~]# find /dev -type b b块设备文件 ⑥按文件权限: [root@qianfeng ~]# find . -perm 644 -ls 关键词perm -ls 是find的动作之一,精确权限 ⑦找到后处理的动作 ACTIONS: 找到后删除 # find /etc -name "qwer.txt" -delete 找到后复制 # find /etc -name "ifcfg*" -ok cp -rvf {} /tmp \; cp -rvf {} /tmp 对比cp /etc/passwd /tmp/etc1 找到的文件 连接符 前面找到的文件 结束符 文件打包及压缩 tar命令是Unix/Linux系统中备份文件的可靠方法, 几乎可以工作于任何环境中,它的使用权限是所有用户。 建议针对目录 打包,压缩 语法:tar 选项 压缩包名称 源文件 ===打包,压缩=== # tar -cf etc.tar /etc # tar -czf etc-gzip.tar.gz /etc/ //z是gzip # tar -cjf etc-bzip.tar.bz /etc/ //j是bzip # tar -cJf etc-xzip.tar.xz /etc/ //J是xzip 观察三个包的体积。 # ll -h etc* -rw-r--r--. 1 root root 11M 10月 14 10:07 etc-gzip.tar.gz -rw-r--r--. 1 root root 8.9M 10月 14 10:08 etc-bzip.tar.bz -rw-r--r--. 1 root root 7.6M 10月 14 10:08 etc-xzip.tar.xz 压缩速度和压缩体积成反比。 解压,解包 查看,并没有解压 # tar -tf etc.tar //t查看f文件名 解压缩 # tar xf etc3.tar.xz # tar -xvf etc2.tar.bz2 -C /tmp //-C重定向到//tmp目录

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端加油站

你遇到的坑将由我来踩

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值