美文网首页Ionic Frameworkionic开发
ionic 关于wx.getLocalImgData 多张图片

ionic 关于wx.getLocalImgData 多张图片

作者: 小圈儿33 | 来源:发表于2019-10-30 10:21 被阅读0次

需求是这样:在微信公众号里面可以批量上传图片。
我们没有用微信的上传图片的方法,而是使用微信的转码方法,转成base64然后上传到自己的oss上面了。如果wx.uploadImage这个方法遇到这个问题,解决方法大概是一样的。

微信的逻辑大致是:

  • 调用wx.chooseImage获取图片的res.localIds(本地id,如果你选择了多张图片,这个返回值就是一个数组)。
  • 然后wx.getLocalImgData方法,传入的参数是每一个localID,得到base64的编码,这里我遇到了一个大大的问题,控制台显示,我这个方法正常调用了,但是success方法里面的代码却没有触发,一次也没有触发。
for(int i = 0;i<res.localIds.length;i++){
      var localId = res.localIds[i];
      wx.getLocalImgData({
          localId: localId, // 图片的localID
          success: function (res) {
            var localData = res.localData;
            //判断是否有这样的头部
            if (localData.indexOf('data:image') != 0)
              localData = 'data:image/jpeg;base64,' +  localData
            //localData是经过处理的base64编码的图片
            localData = localData.replace(/\r|\n/g, '').replace('data:image/jgp', 'data:image/jpeg')
          }
        });
}
        

后来,查了一些资料,大概意思是wx.getLocalImgData这个方法是异步方法,如果想要实现多个图片同时转码,就必须,串行起来,前一个图片转码完成后,才能执行下一张图片的转码。这是微信要求的,所以我就换了一种实现方式,递归方法。如下:

   syncUpload(localIds) {
    var localId = localIds.pop();
    wx.getLocalImgData({
      localId: localId, // 图片的localID
      success: function (resBackData) {
        var localData = resBackData.localData;
        //判断是否有这样的头部
        if (localData.indexOf('data:image') != 0) 
          localData = 'data:image/jpeg;base64,' +  localData
        //localData是经过处理的base64编码的图片
        localData = localData.replace(/\r|\n/g, '').replace('data:image/jgp', 'data:image/jpeg')
        if(localIds.length > 0)
          this.syncUpload(localIds);
       }
    });
  };

但是,多次循环,只有第一次成功执行了,打断点走到this.syncUpload(localIds);这句代码的时候,就再也不执行了,不知道是什么原因,没道理啊。难道这个方法没有成功调用,于是我打印了一下这个this,一看:


this的内容.png

这个this,怎么不是这个类本身呢,怎么变成wx.getLocalImgData了,原来this在异步方法中的作用域被改变了,所以调不到syncUpload()这个方法。知道原因了,那解决办法就好说了,在外层声明一个中间变量存储一下当前this,然后在异步方法里面用这个中间变量去调用方法。上代码:

   syncUpload(localIds) {
    var localId = localIds.pop();
    var self = this;
    wx.getLocalImgData({
      localId: localId, // 图片的localID
      success: function (resBackData) {
        var localData = resBackData.localData;
        //判断是否有这样的头部
        if (localData.indexOf('data:image') != 0) 
          localData = 'data:image/jpeg;base64,' +  localData
        //localData是经过处理的base64编码的图片
        localData = localData.replace(/\r|\n/g, '').replace('data:image/jgp', 'data:image/jpeg')
        if(localIds.length > 0)
          self.syncUpload(localIds);
       }
    });
  };

问题解决。

很长时间以来一直有这样的感悟,如果你发现你写的代码,没问题,没道理执行不通啊,那八成是非常简单的错误。休息一下,换个角度,也许就解决了。

相关文章

网友评论

    本文标题:ionic 关于wx.getLocalImgData 多张图片

    本文链接:https://www.haomeiwen.com/subject/eszgvctx.html