zoukankan      html  css  js  c++  java
  • base64格式文件下载方法

    下载图片时,接口返回的地址是base64格式的文件数据,因为页面需要把base64格式的数据转换为文件,再进行下载:

    解决方案:

      下载按钮:

    <el-button type="default" class="btnfoot" @click="downloadFun">下载</el-button>
    

      下载事件:

      以下方法:downloadFile、base64ToBlob可以直接使用。

      其中,multipleSelection表示所勾选的下载数据列表信息

    downloadFun() {
          console.log(this.multipleSelection);
          for (let i = 0; i < this.multipleSelection.length; i++) {
            const param = {
              Command: 'downloadfile',
              FileName: this.multipleSelection[i].FileName
            }
            videoImgDownload(param).then(response => {
              console.log('videoImgDownload');
              console.log(response);
              if (response.StateCode == '200') {
                this.base64Src = response.FileData;
                this.downloadFile(response.FileName, this.base64Src);
              } else {
                this.$notify({title: '异常', message: response.message, type: 'warning', duration: 0});
              }
            });
          }
        },
        downloadFile(fileName, content) {
          const blob = this.base64ToBlob(content); // new Blob([content]);
          if (window.navigator.msSaveOrOpenBlob) {
            navigator.msSaveBlob(blob, fileName);
          } else {
            const link = document.createElement('a');
            link.href = window.URL.createObjectURL(blob);
            link.download = fileName;
    
            //此写法兼容可火狐浏览器
            document.body.appendChild(link);
            const evt = document.createEvent("MouseEvents");
            evt.initEvent("click", false, false);
            link.dispatchEvent(evt);
            document.body.removeChild(link);
          }
        },
        base64ToBlob(code) {
          const parts = code.split(';base64,');
          const contentType = parts[0].split(':')[1];
          const raw = window.atob(parts[1]);
          const rawLength = raw.length;
          const uInt8Array = new Uint8Array(rawLength);
          for (let i = 0; i < rawLength; ++i) {
            uInt8Array[i] = raw.charCodeAt(i);
          }
          return new Blob([uInt8Array], { type: contentType });
        },
    

      

  • 相关阅读:
    UVa 11991 Easy Problem from Rujia Liu?
    UVa 11995 I Can Guess the Data Structure!
    LA 3485 (积分 辛普森自适应法) Bridge
    LA 5009 (三分法求极值) Error Curves
    软帝学院:一万字的Java基础知识总结大全(实用)
    学java可以做些什么
    从零开始学习java一般需要多长时间?
    学习java需要英语很好吗?
    java的8种基本数据类型
    什么是java变量,java变量是什么
  • 原文地址:https://www.cnblogs.com/luoxuemei/p/10005572.html
Copyright © 2011-2022 走看看