使用 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 >下载</button> 
  <span ></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)