需求是这样:在微信公众号里面可以批量上传图片。
我们没有用微信的上传图片的方法,而是使用微信的转码方法,转成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,怎么不是这个类本身呢,怎么变成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);
}
});
};
问题解决。
很长时间以来一直有这样的感悟,如果你发现你写的代码,没问题,没道理执行不通啊,那八成是非常简单的错误。休息一下,换个角度,也许就解决了。