zoukankan      html  css  js  c++  java
  • 如何处理请求返回的二进制数据流转化成xlsx文件?

    /* fileName : 文件名 res:二进制流 */
    function getOutExcel(fileName, res) {
        let blob = new Blob([res], { type: 'application/x-xls' });
        if (window.navigator.msSaveOrOpenBlob) {
            //兼容 IE & EDGE
            navigator.msSaveBlob(blob, fileName);
        } else {
            var link = document.createElement('a');
            // 兼容不同浏览器的URL对象
            const url = window.URL || window.webkitURL || window.moxURL
            // 创建下载链接
            link.href = url.createObjectURL(blob);
            //命名下载名称
            link.download = fileName;
         document.body.appendChild(link) //点击触发下载 link.click(); //下载完成进行释放 url.revokeObjectURL(link.href); } } getOutExcel('文件名字.xlsx',res)


    注意添加响应数据的类型{ responseType: 'blob' }
      在和后台交互的时候,如果后台返回给我们的是二进制流数据,我们就要在发送的时候加上{responseType:'blob'}这行代码,这样返回给我们的就不是乱码了。

  • 相关阅读:
    js前端分享功能
    git常用命令
    webstorm中.vue报错
    页面重绘重排
    浏览器渲染引擎总结
    javascript中的this总结
    cookie、session、sessionid 与jsessionid
    promise和Angular中的 $q, defer
    C++11之nullptr
    C++ 输入ctrl+z 不能再使用cin的问题
  • 原文地址:https://www.cnblogs.com/changxue/p/10947384.html
Copyright © 2011-2022 走看看