微信小程序实现上传多张本地图片到服务器和图片预览

1,前言


最近在写小程序,用到了wx.uploadFile方法,发现这方法居然不支持同时上传多个文件,于是自己写了一个上传多个的方法。

wx.uploadFile接口描述

2,需求


博主做的是用户投诉页面;需求是用户上传最多三张图片,最后把图片和文字和用户信息等一起提交给服务器;

UI样式

3,解决思路


博主的解决思路是定义一个递归函数,递归调用wx.uploadFile上传,全部完成后结束递归。

4,代码展示


this.data里的数据

/**
* 页面的初始数据
*/
data: {
 imgs:[],//上传图片列表
 imgPath:[],//已上传成功的图片路径
},

上传图片代码

// 上传照片
chooseImg (e) {
  const _this = this;
  let imgs = this.data.imgs;
  let imgNumber = this.data.imgs.length;//当前已上传的图片张数
  if(imgNumber >= 3){
    FN.Toast("超出上传个数");
    return false;
  }else{
    imgNumber = 3 - imgNumber;
  };
  wx.chooseImage({//打开本地相册选择图片
    count: imgNumber,
    sizeType: ['original', 'compressed'],
    sourceType: ['album', 'camera'],
    success (res) {
      const tempFilePaths = res.tempFilePaths;
      for(let i = 0;i < tempFilePaths.length; i++){
        imgs.push(tempFilePaths[i]);
      }
      _this.setData({//赋值,回显照片
        imgs: imgs
      });
      let successUp = 0; //成功
      let failUp = 0; //失败
      let count = 0; //第几张
      let length = tempFilePaths.length; //总数
      _this.recursionUploading(tempFilePaths, successUp, failUp, count, length);//调用上传方法
    }
  })
},

递归上传方法

//采用递归的方式上传图片
recursionUploading(imgPaths, successUp, failUp, count, length){
  var _this = this;
  wx.showLoading({
  title: '正在上传第' + count + '张',
  });
  wx.uploadFile({
    url: `${app.globalData.baseURL}/api接口地址`,
    filePath: imgPaths[count],
    formData:{
      userId:app.globalData.userMsg.userId
    },
    name: "uploadImage",
    header: {
      'content-type': 'multipart/form-data'
    }, 
    success (e) {
      console.log(e)
      let path = _this.data.imgPath;
      let obj = e.data;
      if(obj.status === "y"){
        path.push(obj.infoObject);
        _this.setData({
          imgPath:path
        });
      }
      successUp++;//成功+1
    },
    fail (e) {
      failUp++;//失败+1
    },
    complete (e) {
      count++;//下一张
      if(count == length){
      	FN.Toast(`上传成功${successUp}`)
      }else{
        //递归调用,上传下一张
        _this.recursionUploading(imgPaths, successUp, failUp, count, length);
      }
    }
  })
},

预览大图

// 预览大图
lookBigImg (e) {
  let index = e.currentTarget.dataset.index;//索引
  let big = this.data.imgs[index];
  wx.previewImage({
    current: big, // 当前显示图片的http链接
    urls: this.data.imgs // 需要预览的图片http链接列表
  })
},

如果看了觉得有帮助的,我是@上进的鹏多多,欢迎 点赞 关注 评论;
END

面向百度编程

往期文章

个人主页

posted @   鹏多多  阅读(3213)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示