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

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 win11账户锁定时间设为0无法登录
  • ¥45 C#学生成绩管理系统
  • ¥15 VB.NET2022如何生成发布成exe文件
  • ¥30 matlab appdesigner私有函数嵌套整合
  • ¥15 vb6.0使用jmail接收smtp邮件并另存附件到D盘
  • ¥30 vb net 使用 sendMessage 如何输入鼠标坐标
  • ¥15 关于freesurfer使用freeview可视化的问题
  • ¥100 谁能在荣耀自带系统MagicOS版本下,隐藏手机桌面图标?
  • ¥15 求SC-LIWC词典!
  • ¥20 有关esp8266连接阿里云