微信小程序上传图片每次只能上传一张,所有很多朋友就会问想要多张图片上传怎么办?

这里使用递归,当上传完一张图片后重新执行这个函数,直到所有的图片都上传完成后,就不再调用该函数。

首先,我们来看一看wx.chooseImage(object)和wx.uploadFile(OBJECT)这两个api

示例代码是这样的:

  1. wx.chooseImage({
  2. success: function(res) {
  3. var tempFilePaths = res.tempFilePaths
  4. wx.uploadFile({
  5. url: 'http://example.weixin.qq.com/upload', //仅为示例,非真实的接口地址
  6. filePath: tempFilePaths[0],
  7. name: 'file',
  8. formData:{
  9. 'user': 'test'
  10. },
  11. success: function(res){
  12. var data = res.data
  13. //do something
  14. }
  15. })
  16. }
  17. })

这里的示例代码,是选择图片,然后上传选中的图片中的第一个图片;

现在开始写多张图片上传的例子

首先,我们还是要选择图片

  1. wx.chooseImage({
  2. success: function(res) {
  3. var tempFilePaths = res.tempFilePaths;//这里是选好的图片的地址,是一个数组
  4.  
  5. }
  6. })

然后在app.js中写一个多张图片上传的方法,后面引入,你也可以写在一个JS文件中,后面引入:

  1. //多张图片上传
  2. function uploadimg(data){
  3. var that=this,
  4. i=data.i?data.i:0,//当前上传的哪张图片
  5. success=data.success?data.success:0,//上传成功的个数
  6. fail=data.fail?data.fail:0;//上传失败的个数
  7. wx.uploadFile({
  8. url: data.url,
  9. filePath: data.path[i],
  10. name: 'file',//这里根据自己的实际情况改
  11. formData:null,//这里是上传图片时一起上传的数据
  12. success: (resp) => {
  13. success++;//图片上传成功,图片上传成功的变量+1
  14. console.log(resp)
  15. console.log(i);
  16. //这里可能有BUG,失败也会执行这里,所以这里应该是后台返回过来的状态码为成功时,这里的success才+1
  17. },
  18. fail: (res) => {
  19. fail++;//图片上传失败,图片上传失败的变量+1
  20. console.log('fail:'+i+"fail:"+fail);
  21. },
  22. complete: () => {
  23. console.log(i);
  24. i++;//这个图片执行完上传后,开始上传下一张
  25. if(i==data.path.length){ //当图片传完时,停止调用
  26. console.log('执行完毕');
  27. console.log('成功:'+success+" 失败:"+fail);
  28. }else{//若图片还没有传完,则继续调用函数
  29. console.log(i);
  30. data.i=i;
  31. data.success=success;
  32. data.fail=fail;
  33. that.uploadimg(data);
  34. }
  35.  
  36. }
  37. });
  38. }

多张图片上传的方法写好了,下面就是引用:

  1. var app=getApp();
  2. Page({
  3. data:{
  4. pics:[]
  5. },
  6. choose:function(){//这里是选取图片的方法
  7. var that=this,
          pics=this.data.pics;
  8. wx.chooseImage({
  9. count: 9-pics.length, // 最多可以选择的图片张数,默认9
  10. sizeType: ['original', 'compressed'], // original 原图,compressed 压缩图,默认二者都有
  11. sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
  12. success: function(res){
  13. var imgsrc=res.tempFilePaths;
             pics=pics.concat(imgsrc);
  14. that.setData({
  15. pics:pics
  16. });
  17. },
  18. fail: function() {
  19. // fail
  20. },
  21. complete: function() {
  22. // complete
  23. }
  24. })
  25.  
  26. },
  27. uploadimg:function(){//这里触发图片上传的方法
  28. var pics=this.data.pics;
  29. app.uploadimg({
  30. url:'https://........',//这里是你图片上传的接口
  31. path:pics//这里是选取的图片的地址数组
  32. });
  33. },
  34. onLoad:function(options){
  35.  
  36. }
  37.  
  38. })

刚好写了一个node上传图片代码,亲测可以使用,

一个简单的PHP接收代码:

  1. <?php
  2. $imgname = $_FILES['file']['name'];
  3. $tmp = $_FILES['file']['tmp_name'];
  4. $filepath = 'now/';//记得要自己创建这个文件夹
  5. if(move_uploaded_file($tmp,$filepath.$imgname.".png")){
  6. echo "上传成功";
  7. }else{
  8. echo "上传失败";
  9. }
  10.  
  11. ?>

完结。

想了解更多的小程序的知识请添加微信小程序开发交流群:368506119

微信小程序多张图片上传的更多相关文章

  1. [转]微信小程序实现图片上传功能

    本文转自:http://blog.csdn.net/feter1992/article/details/77877659 前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何 ...

  2. nodeJs实现微信小程序的图片上传

    今天我来介绍一下nodejs如何实现保存微信小程序传过来的图片及其返回 首先wx.uploadFile绝大部分时候是配合wx.chooseImage一起出现的,毕竟选择好了图片,再统一上传是实现用户图 ...

  3. 微信小程序实现图片上传功能

    前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何实现上传图片到自己的服务器上 前端代码 data: { productInfo: {} }, //添加Banner bin ...

  4. 微信小程序--实现图片上传

    前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何实现上传图片到自己的服务器上 前端代码 data: { productInfo: {} }, //添加Banner bin ...

  5. 微信小程序中图片上传阿里云Oss

    本人今年6月份毕业,最近刚在上海一家小公司实习,做微信小程序开发.最近工作遇到一个小问题. 微信小程序图片上传阿里云服务器Oss也折腾了蛮久才解决的,所以特意去记录一下. 第一步:配置阿里云地址: 我 ...

  6. [组件封装]微信小程序-图片批量上传照片墙

    描述 批量上传图片, 可设置最大上传个数, 可删除, 可设置默认值. 效果 源码 pictures-wall.wxml <view class="picturesWall"& ...

  7. 微信小程序 多图上传解决方案

    为了使代码体积小  我这里将多图上传 封装到单独的一个js 页面的js调用他 我们看firhealth.js文件内容 // pages/home/home.js var upload = requir ...

  8. 微信小程序实现图片上传,预览,删除

    wxml: <view class='imgBox'> <image class='imgList' wx:for="{{imgs}}" wx:for-item= ...

  9. 微信小程序wx.uploadFile 上传文件 的两个坑

    fileUpload: function (tempFilePath) { var that = this;//坑1: this需要这么处理 wx.uploadFile({ url: url地址, / ...

随机推荐

  1. java多线程基本概述(五)——线程通信

    线程之间的通信可以通过共享内存变量的方式进行相互通信,也可以使用api提供的wait(),notify()实现线程之间的通信.wait()方法是Object类的方法,改方法用来将当前的线程置入&quo ...

  2. Android -- 带你从源码角度领悟Dagger2入门到放弃

    1,以前的博客也写了两篇关于Dagger2,但是感觉自己使用的时候还是云里雾里的,更不谈各位来看博客的同学了,所以今天打算和大家再一次的入坑试试,最后一次了,保证最后一次了. 2,接入项目 在项目的G ...

  3. 【Java】大文本字符串滤重的简单方案~

    本文章也同步至本人的CSDN博客中: http://blog.csdn.net/u012881584/article/details/70477832 今天来说一个Java中处理大文本字符串虑重的两个 ...

  4. 【uwp】浅谈China Daily中数据同步到One Drive的实现

    新版China Daily与旧版相比新增了数据同步的功能,那这个功能具体是如何实现的呢,现在让我们来一起看看. 1.注册应用 开发者中心的应用注册就不用多说了(https://developer.mi ...

  5. HTTP笔记

    "你知道当我们在网页浏览器(Web browser)的地址栏中输入 URL 时,Web 页面是如何呈现的吗?" HTTP协议 HTTP协议(HyperText Transfer P ...

  6. SpringMVC结合ajaxfileupload文件无刷新上传

    jQuery没有提供ajax的文件上传,我们可以通过ajaxfileupload实现ajax文件的上传.其实ajaxfileupload文件上传特别的简单.下面就演示一下在SpringMVC中实现aj ...

  7. PHP获取Post的原始数据方法小结(POST无变量名)

    From : http://blog.csdn.net/hotdigger/article/details/6456240   一般我们都用$_POST或$_REQUEST两个预定义变量来接收POST ...

  8. 在myeclipse下安装svn插件,出现了Could not generate DH keypair,这么一个错误。

    解决方法: window-->preferences-->Team-->SVN-->SVN接口 选择:JavaHL 去https://sliksvn.com/download/ ...

  9. Nginx 常用配置整理

    #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_processes 8; #全局错误日志定义类型,[ debug | ...

  10. session与cookie-----2017-05-08

    会话控制:目的是记录不同用户身份. 1.session:有实效性 特点: (1)存在在服务器 (2)每个用户都会存一份 (3)可以存储任意类型的数据 优点:安全性高 缺点:服务器压力过大 2.cook ...