• 使用 javascript API -- fetch 实现文件下载功能


    下载原理

    下载原理很简单,就是模拟 a 标签的点击下载,我们都知道 ajax 不支持下载文件功能,是因为 ajax 只能用来传输字符型数据,所以在过去无法使用 ajax 来下载文件。
    xhr2 可以把 response 保存为 blob,下载结束后,为这个 blob 创建一个 URL,跳转到这个URL,或使用 anchor element with download property ,浏览器会弹出保存框。如果文件很大的话,还需要用到 filesystem API,因为 blob 是存在内存中的。(来自知乎:鲁小夫

    简单的实现方式

    <!DOCTYPE html> 
    <html> 
    <head> 
      <meta charset="utf-8"> 
      <title>sample</title> 
    </head> 
    <body> 
      <button id='download'>下载</button> 
      <span id='status'></span> 
    </body> 
    <script> 
      var url = "http:// your files link"; 
      document.querySelector('#download').onclick = function() { 
        document.querySelector('#status').innerHTML = '文件下载中...'; 
        fetch(url).then(res => res.blob().then(blob => { 
          var a = document.createElement('a'); 
          var url = window.URL.createObjectURL(blob);   // 获取 blob 本地文件连接 (blob 为纯二进制对象,不能够直接保存到磁盘上)
          var filename = res.headers.get('Content-Disposition'); 
          a.href = url; 
          a.download = filename; 
          a.click(); 
          window.URL.revokeObjectURL(url); 
          document.querySelector('#status').innerHTML = '下载完成'; 
        })); 
      }; 
    </script> 
    </html>
    

    关于 window.URL.createObjectURL(blob)window.URL.revokeObjectURL(objectURL)

  • 相关阅读:
    HTML页面跳转的5种方法
    ngixn配置
    redis秒杀
    php 设计模式
    MySQL之事务的四大特性
    [置顶] JNI之java传递数据给c语言
    jQuery 快速结束当前动画
    编绎OpenJDK
    CF#231DIV2:A Good Number
    CF#213DIV2:B The Fibonacci Segment
  • 原文地址:https://www.cnblogs.com/YMaster/p/7707989.html
Copyright © 2020-2023  润新知