• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

微信小程序开发——base64位图片显示问题 - 逍遥云天

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

微信小程序开发——base64位图片显示问题

前言:

目前小程序项目需要后端借口提供验证码图片,后端是以base64位返回的,按照H5的做法,前边拼上 data:image/png;base64, 应该就可以了,关键代码如下:

H5:

<img :src="asynImg" @click="getImage();" class="code">
_self.asynImg = \'data:image/png;base64,\' + response.data.data;

如此,显示正常,没有做任何特殊处理。

小程序:

<image class=\'fr\' wx:if="{{validate_code_data&&validate_code_data.data}}" src="data:image/png;base64,{{validate_code_data.data}}"></image>

当然也可以直接在js中把base64位的格式头拼接在数据的前边,这个并不影响。关键是小程序种,图片竟然不显示了,这是为什么呢?

异常解析:

 

看下后台返回的数据:

可以看到,后台返回的base64数据是有换行的,经查证,后端返回的base64位数据是一致的,包括编译后的html和wxml代码结构层面都是一样的,这只能说明小程序兼容性不如h5了。

那么我们就需要在小程序种对后端提供的数据进行去换行处理了,关键代码如下:

解决方案:

      var base64 = res && res.data
      if (base64) {
        base64 = base64.replace(/[\r\n]/g, "")
        res.data = base64
        self.setData({
          validate_code_data: res
        })
      }

如上,只需一行代码,即可完美展示验证码。

后记:

网上还有另一种处理方法,如下:

var array = wx.base64ToArrayBuffer(res.data)
var base64 = wx.arrayBufferToBase64(array)
that.setData({ captchaImage: \'data:image/png;base64,\' + base64});

这种方法是可以显示图片,但是有些不正常。具体表现是连续点击会出现图片不显示,控制台报错:

VM1437:1 thirdScriptError
"atob" failed;undefined
Error: "atob" failed

调试了下,报错的时候在第二行代码这里 var base64 = wx.arrayBufferToBase64(array) 变量已经为空了,也就是这个转换出了问题。

网上查了下,这个问题应该还是后端返回的base64串带换行导致的,如果要使用这种方式,也是需要在前边去掉换行的。

不过话又说回来了,既然去掉换行能处理这个问题,那么还何必再多加两行转换的代码呢。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
    热门话题
    阅读排行榜

    扫描微信二维码

    查看手机版网站

    随时了解更新最新资讯

    139-2527-9053

    在线客服(服务时间 9:00~18:00)

    在线QQ客服
    地址:深圳市南山区西丽大学城创智工业园
    电邮:jeky_zhao#qq.com
    移动电话:139-2527-9053

    Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap