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日

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装