jq获取页面中所有的a链接并执行下载功能

本文探讨了一个在JavaScript中使用each方法批量下载文件时遇到的bug,即只执行最后一项下载任务。通过修改代码逻辑,使用自定义函数downfileByFileId解决了这一问题,确保所有文件都能被正确下载。同时,文中还提到了不同浏览器如IE、Chrome和Firefox在处理多文件下载时的行为差异。

首先记录一下BUG

  最开始一直是以以下方式进行下载的,但是发现,他只会下载最后一条数据,但是你在调试过程中或者alert的时候他又能全部执行下载,这真是一个很奇怪的问题,为此研究了好久

  错误代码如下:

  

$('#fromHTMLtestdiv').find("a").each(function (i) {

  this.click();  
}

正确代码如下

function downfileByFileId(fileId,i) {
            var loadFrameId = "#dFF" + i;
            //var loadFrame = $(loadFrameId);

            var loadFrameEm = "<iframe id=\"" + loadFrameId + "\"  src=\"" + fileId + "\"  style=\"display:none;\"></iframe>";
            $(document.body).append(loadFrameEm);


}


$('#fromHTMLtestdiv').find("a").each(function (i) {
                downfileByFileId($('#fromHTMLtestdiv').find("a")[i].href,i);

});

     另外需要注意的是,因为ie浏览器有限制,所以在ie浏览器上运行的时候还是下载一个文件,当换成谷歌或者火狐浏览器的时候,也会在浏览器的右上角弹出个提示“是否允许多文件下载”,只有点击同意的时候才会下载多个文件

转载于:https://www.cnblogs.com/dushaojun/p/9995451.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值