real47LEBJ 2023-01-10 10:53 采纳率: 95.7%
浏览 65
已结题

JavaScript利用a标签下载文件遇到的问题

场景描述:
勾选checkbox可以获取到该文件的所在路径(支持多选),并存储到一个数组中,以供a标签下载使用,图中蓝色的下载是一个a标签。点击下载后根据数组的长度打开对应数量的下载页面。

img

遇到的问题:1. 点击下载后,如何根据数组长度打开相应数量的下载页面? (动态创建dom节点?)
2.遍历数组后如何给a标签的属性赋值 (我给download属性赋值后可以下载到文件,文件后缀是.log但实际内容是本页面源码)

补充: 后台给的json如下:

img

  • 写回答

2条回答 默认 最新

  • 球球和皮皮 2023-01-10 14:06
    关注

    搞定:

    img

    let fileList = [
        {
            fileName: 'cat.jpeg',
            filePath: 'https://fastly.jsdelivr.net/npm/@vant/assets/cat.jpeg'
        },
        {
            fileName: 'cat.jpeg',
            filePath: 'https://fastly.jsdelivr.net/npm/@vant/assets/cat.jpeg'
        },
        {
            fileName: 'cat.jpeg',
            filePath: 'https://fastly.jsdelivr.net/npm/@vant/assets/cat.jpeg'
        }
    ]
    
    fileList.forEach(item => {
        let filename = item.fileName
        // 将blob对象转为一个URL
        var blobURL = item.filePath
        // 创建一个a标签
        var tempLink = document.createElement("a");
        // 隐藏a标签
        tempLink.style.display = "none";
        // 设置a标签的href属性为blob对象转化的URL
        tempLink.href = blobURL;
        // 给a标签添加下载属性
        tempLink.setAttribute("download", filename);
        // 将a标签添加到body当中
        document.body.appendChild(tempLink);
        // 启动下载
        tempLink.click();
        // 下载完毕删除a标签
        document.body.removeChild(tempLink);
        window.URL.revokeObjectURL(blobURL);
    })
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月19日
  • 已采纳回答 1月11日
  • 创建了问题 1月10日

悬赏问题

  • ¥15 对于这个复杂问题的解释说明
  • ¥50 三种调度算法报错 采用的你的方案
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败