当前位置:首页 » 《关于电脑》 » 正文

前端 JS 经典:文件流下载

10 人参与  2024年05月03日 10:05  分类 : 《关于电脑》  评论

点击全文阅读


重点:调用接口时,一定要配置 responseType 的值为 blob,不然获取的文件流,不会转义成 blob 类型的文件。

1. 接口返回文件流

// BLOB (binary large object)----二进制大对象,是一个可以存储二进制文件的容器// 下载接口:重点responseType: "blob"// 返回体 res blob 文件流function downloadFile(params) {  return api({    url: "/download/file",    method: "get",    params,    responseType: "blob",  });}

2. 文件流下载:简单版

/** * 下载函数 * @param {string} data - 后端获取的文件流 * @param {string} name - 文件名 */function downloadFile(data, name) {  const blob = new Blob([data]);  const url = window.URL.createObjectURL(blob);  const a = document.createElement("a");  a.href = url;  a.download = name;  document.body.appendChild(a);  a.style.display = "none";  a.click();  document.body.removeChild(a);}

3. 文件流下载:豪华版

/** * 全面优化下载函数 */function downloadFile(res) {  // 判断是否接口调用是否正常返回文件流  const r = new FileReader();  r.readAsText(res.data);  r.onload = () => {    try {      // 报错,未返回      const resData = JSON.parse(r.result);    } catch (err) {      // 正常,开始转换文件流      // 正常情况,浏览器不返回字段为 content-disposition 的请求头,      // 需要后端特殊声明下,才拿得到,response.setHeader("Access-Control-Expose-Headers","Content-Disposition");      const name = res.headers["content-disposition"];      const fileName = name.split("=")[1];      // 解码      filename = decodeURIComponent(fileName);      // 兼容ie11      if (window.navigator.msSaveOrOpenBlob) {        try {          const blobObject = new Blob([res.data]);          window.navigator.msSaveOrOpenBlob(blobObject, fileName);        } catch (e) {          console.log(e);        }        return;      }      // a标签实现下载      const url = window.URL.createObjectURL(new Blob([res.data]));      const a = document.createElement("a");      a.style.display = "none";      a.href = url;      a.download = filename;      document.body.appendChild(a);      a.click();      resolve(fileName);      document.body.removeChild(a);    }  };}


点击全文阅读


本文链接:http://zhangshiyu.com/post/103046.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1