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

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日

悬赏问题

  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥15 pyqt信号槽连接写法
  • ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。