sunbaoxu

上传图片功能应该是现在比较常见的需求了,但是上传的图片大小、压缩、个数限制以及回显点击放大等还是比较麻烦。

这里我简单以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)
	   }
      })
    })
  }	
};               

  

  

 

分类:

技术点:

相关文章: