• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1,前言


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

2,需求


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

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

往期文章

个人主页


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
微信小程序代码上传,审核发布小程序发布时间:2022-07-18
下一篇:
微信小程序 多图上传解决方案发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap