js下载文件方式总结

 1、使用路径只能下载图片:

 downloadByBlob(url,name) {
    let image = new Image()
    image.setAttribute('crossOrigin', 'anonymous')
    image.src = url
    image.onload = () => {
    let canvas = document.createElement('canvas')
    canvas.width = image.width
    canvas.height = image.height
    let ctx = canvas.getContext('2d')
    ctx.drawImage(image, 0, 0, image.width, image.height)
    canvas.toBlob((blob) => {
    let url = URL.createObjectURL(blob)
    this.download(url,name)
    // 用完释放URL对象
    URL.revokeObjectURL(url)
   })
  }
 }


 download(href, name) {
     let eleLink = document.createElement('a')
     eleLink.download = name
     eleLink.href = href
     eleLink.click()
     eleLink.remove()
 },

2、使用路径下载文件(所有文件都可以下载)

let url = window.URL.createObjectURL(new Blob([hreLocal])) //创建下载链接
let link = document.createElement('a') //创建a标签
link.style.display = 'none'  //将a标签隐藏
link.href = url  //给a标签添加下载链接
// 此处注意,要给a标签添加一个download属性,属性值就是文件名称 
否则下载出来的文件是没有属性的,空白白
link.setAttribute('download', name) 
document.body.appendChild(link)
link.click()

3、调接口、传参,下载文件:

axios.post(请求路径URL,{参数}),{
    responseType:'blob'
}.then((res)=>{
    this.handledownloadFiles(下载路径)
    
})
//type:application/zip为下载压缩包
handledownloadFiles(data) {
    //创建下载链接
   let url = window.URL.createObjectURL(new Blob([data], {type: 'application/zip'}));
   //创建a标签
   let link = document.createElement('a');
    /将a标签隐藏
   link.style.display = 'none';
    //给a标签添加下载链接
   link.href = url;
    // 此处注意,要给a标签添加一个download属性,属性值就是文件名称
       否则下载出来的文件是没有属性的,空白白
   link.setAttribute('download.txt', " ");
   document.body.appendChild(link);
   link.click();
},

上面踩坑下载pdf打不开

使用XMLHttpRequest对象

  let request = new XMLHttpRequest();
       request.responseType = "blob";//定义响应类型
       request.open("GET", fileUrl);
       request.onload = function () {
          let url = window.URL.createObjectURL(this.response);
          let a = document.createElement("a");
          document.body.appendChild(a);
          a.href = url;
          a.download = fileName
          a.click();
        }
        request.send();

参考博客:https://blog.csdn.net/qq_19313497/article/details/104234723?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-2.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-2.control

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值