Ionic Frameworkionic开发

ionic 关于wx.getLocalImgData 多张图片

2019-10-30  本文已影响0人  小圈儿33

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

微信的逻辑大致是:

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);
       }
    });
  };

问题解决。

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

上一篇 下一篇

猜你喜欢

热点阅读