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'}这行代码,这样返回给我们的就不是乱码了。

  • 相关阅读:
    POJ3164 Command Network
    UVa11401 Triangle Counting
    UVa11174 Stand in a Line
    UVa11806 Cheerleaders
    Uva11538 Chess Queen
    Bzoj3130 [Sdoi2013]费用流
    Bzoj3262 陌上花开
    模拟25A 题解
    模拟24 题解
    模拟23 题解
  • 原文地址:https://www.cnblogs.com/changxue/p/10947384.html
Copyright © 2011-2022 走看看