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

  • 相关阅读:
    TP框架 商城前台用户注册方法
    小知识
    TP框架中的一些登录代码分享
    js贪吃蛇小游戏
    关于jQ的小案例分享
    vb语法
    ruby file
    ruby的next if boolean
    ruby文件操作
    vue里面的this指向
  • 原文地址:https://www.cnblogs.com/changxue/p/10947384.html
Copyright © 2011-2022 走看看