zoukankan      html  css  js  c++  java
  • uni-app 实现后端返回的图片文件流转base64

    使用uni-app开发webapp,由于后端返回的图片文件是二进制文件流形式,前端展示需要转换格式,首先想到的就是转成base64进行展示,话不多说,直接填坑。

    使用uni-app的uni.request进行网络请求,在网上查找的资料是如果返回的是文件流需要设置responseType为‘bold’类型,uni-app官网文档描述:设置响应的数据类型。合法值:text、arraybuffer。

    故需要设置responseType为arraybuffer类型。

    return request({
            method: "GET", // 请求方式
              url: platFormUrl+'/downFile.do', // 请求url
               responseType:'arraybuffer',
               data: data // 参数
            })

    请求拿到数据之后转换成blod对象,blod对象转base64

    let blob = new Blob([res],{type: 'image/png'})

      this.blobToDataURL(blob,(res)=>{
        console.log(res)
      })

    blod对象转base64方法

    blobToDataURL(blob, callback) {
       let a = new FileReader();
       a.onload = function(e) {
          callback(e.target.result);
       }
       a.readAsDataURL(blob);
    }
  • 相关阅读:
    暑期学习录
    08管道命名符
    07输入输出重定向
    06grep与find命令详解
    05tar命令详解
    04文件目录管理命令
    03工作目录切换命令与文本文件编辑命令
    02系统状态检测命令
    01常用系统工作命令
    vue2.0细节剖析
  • 原文地址:https://www.cnblogs.com/zhanglongke/p/14296447.html
Copyright © 2011-2022 走看看