当前位置:   article > 正文

小程序之批量上传图片_小程序批量上传图片 csdn

小程序批量上传图片 csdn

小编推荐:Fundebug专注于JavaScript、微信小程序、微信小游戏,Node.js和Java实时BUG监控。真的是一个很好用的bug监控费服务,众多大佬公司都在使用。

上传图片在项目中属于一个常见场景。在小程序中同样遇到了这样的需求。如何去解决呢?
利用wx.chooseImage(),wx.uploadFile()两个接口即可完成小程序的批量上传图片。

1, 知己知彼,百战不殆(先来瞅瞅这两个api的主要参数)

wx.chooseImage()

从本地相册选择图片或使用相机拍照。

主要参数:
count:控制选择图片张数至多9张;
sizeType: 选择图片尺寸(压缩:compressed or 原图:original);
sourceType: 图片来源(相册:album or 拍照:camera)

wx.uploadFile()

   将本地资源上传到服务器。客户端发起一个 HTTPS POST 请求,其中 content-type 为 multipart/form-data

主要参数:
url: 图片上传接口;
filePath: 上传资源路径(string);
name: 文件对应的 key,(与后台接口约定的key);

wx.chooseImage成功返回值res.tempFilePaths为所选资源路径数组
wx.uploadFile的filePath入参必须为string且是生效的资源路径方能上传成功,故需要采用递归的方法循环调用方能实现批量上传。

2, 工欲善其事必先利其器(进行批量上传的封装)

util.js

  1. /*
  2. * 批量上传函数
  3. * @params {*} params 上传入参对象
  4. * @params {Function} callbackFn 循环回调函数
  5. * @params {Function} successFn 成功回调函数
  6. */
  7. const batchUpload = (params,callBack,successFn) => {
  8. if(!params.uploadUrl) {
  9. console.log('请传入上传地址')
  10. return
  11. }
  12. if(!(params.imgPaths instanceof Array)) {
  13. console.log('请传入array类型')
  14. return
  15. } // 校验传入是否为数组
  16. let maxLength = params.imgPaths.length // 传入数组长度
  17. let i = params.subscript?params.subscript:0 // 当前上传图片下标
  18. let successNum = params.successNum?params.successNum:0 // 上传成功数
  19. let failNum = params.failNum?params.failNum:0 // 上传失败数
  20. let resultData = params.resultData?params.resultData:[] // 上传返回的imgUrl
  21. let endData = {} // 成功回调暴露出去的结果
  22. wx.uploadFile({
  23. url: params.uploadUrl,
  24. filePath: params.imgPaths[i],
  25. name: 'test_batchUpload',
  26. headers: {
  27. "Content-Type": "multipart/form-data"
  28. },
  29. formData: {
  30. // 其它参数
  31. },
  32. success(res) { // 返回code为指定结果表示上传成功反之上传失败
  33. if (res.statusCode == 200) {
  34. let data = JSON.parse(res.data)
  35. successNum++
  36. resultData.push(data.url)
  37. }else {
  38. failNum++
  39. }
  40. },
  41. fail(res) {
  42. failNum++
  43. },
  44. complete() {
  45. i++
  46. if(i==maxLength) { // 上传完毕调用成功回调暴露指定数据出去
  47. endData = {
  48. imgPaths:resultData,
  49. successNum:successNum,
  50. failNum: failNum,
  51. }
  52. successFn(endData)
  53. }else{ // 执行下一张上传
  54. params.subscript = i
  55. params.successNum = successNum
  56. params.failNum = failNum
  57. params.resultData = resultData
  58. // console.log(_that,'_that')
  59. callBack(params,callBack,successFn)
  60. }
  61. }
  62. })
  63. }
  64. export {
  65. batchUpload,
  66. }

3, 项目中引用

index.js

  1. import batchUpload form '../util/util.js'
  2. Page({
  3. data:{
  4. showImage:[]
  5. }
  6. uploadImg() {
  7. let that = this
  8. wx.chooseImage({
  9. count: 6,
  10. success(res) {
  11. const tempFilePaths = res.tempFilePaths
  12. let file = tempFilePaths[0];
  13. let params = {
  14. uploadUrl: 'test_url', // 图片上传接口
  15. imgPaths: tempFilePaths
  16. }
  17. batchUpload(params,batchUpload,(res)=>{
  18. let showImage = that.data.showImage
  19. showImage = res.imgPaths
  20. that.setData({
  21. showImage
  22. },()=>{
  23. let msg = '成功上传'+res.successNum+"张,失败"+res.failNum+"张"
  24. wx.showToast({
  25. title:msg
  26. })
  27. })
  28. })
  29. }
  30. })
  31. }
  32. })

4,效果图

[图片上传失败...(image-353ab7-1553483695861)]
[图片上传失败...(image-a789e3-1553483695861)]

5, 其它

a, 批量封装函数中对上传文件大小的监控
b, 加上uploadTask可以实现上传进度的监控
...

作者:齐梓曦
链接:https://www.jianshu.com/p/f298c92c74b8
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

你可能感兴趣的

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/326023
推荐阅读
相关标签
  

闽ICP备14008679号