上传图片功能应该是现在比较常见的需求了,但是上传的图片大小、压缩、个数限制以及回显点击放大等还是比较麻烦。
这里我简单以uniapp举例说一下常用的方法以及实现的逻辑
首先上传图片需要调用chooseImage ,这里需要说一下count ,默认为最多9可以上传9张图
//最多9张图,this.imgArr为已上传的图片,如果只是1张图的话,可以直接指定count 为1
let count = 9 - this.imgArr.length;
uni.chooseImage({
count,
sourceType: ['album','camera'],
sizeType: ['compressed'],
success(res) {
if(res.errMsg =='chooseImage:ok'){
//res.tempFilePaths 为返回的图片数组
console.log(res.tempFilePaths)
}
}
})
然后需要涉及到给后端传递的数据为什么类型,如果为base64的话,那我们还需对res.tempFilePaths 进行转换
//使用arrayBufferToBase64,但是部分ios机型不兼容
uni.request({ url, method:'GET', responseType: 'arraybuffer', success: ress => { let base64 = wx.arrayBufferToBase64(ress.data); if(type == 'mp4'){ base64=`data:video/mp4;base64,${base64}` }else{ base64=`data:image/jpg;base64,${base64}` } console.log(base64) } })
兼容解决方案
urlTobase64 =(url)=>{ let type=url.substring(url.lastIndexOf('.')+1) if(url.indexOf('.jpg')>0 || url.indexOf('.JPG')>0 || url.indexOf('.PNG')>0 || url.indexOf('.png')>0 || url.indexOf('ttp://tmp/')>0 || url.indexOf('xfile://tmp')>0){ return new Promise((resolve,reject)=>{ wx.getFileSystemManager().readFile({ filePath:url, encoding:'base64', success: res=>{ let base64=''; if(type == 'mp4'){ base64=`data:video/mp4;base64,${res.data}` }else{ base64=`data:image/jpg;base64,${res.data}` } resolve(base64) } }) }) }else{ return new Promise((resolve,reject)=>{ uni.request({ url, method:'GET', responseType: 'arraybuffer', success: ress => { let base64 = wx.arrayBufferToBase64(ress.data); if(type == 'mp4'){ base64=`data:video/mp4;base64,${base64}` }else{ base64=`data:image/jpg;base64,${base64}` } resolve(base64) } }) }) } };