微信小程序多张图片上传
微信小程序上传图片每次只能上传一张,所有很多朋友就会问想要多张图片上传怎么办?
这里使用递归,当上传完一张图片后重新执行这个函数,直到所有的图片都上传完成后,就不再调用该函数。
首先,我们来看一看wx.chooseImage(object)和wx.uploadFile(OBJECT)这两个api
示例代码是这样的:
- wx.chooseImage({
- success: function(res) {
- var tempFilePaths = res.tempFilePaths
- wx.uploadFile({
- url: 'http://example.weixin.qq.com/upload', //仅为示例,非真实的接口地址
- filePath: tempFilePaths[0],
- name: 'file',
- formData:{
- 'user': 'test'
- },
- success: function(res){
- var data = res.data
- //do something
- }
- })
- }
- })
这里的示例代码,是选择图片,然后上传选中的图片中的第一个图片;
现在开始写多张图片上传的例子
首先,我们还是要选择图片
- wx.chooseImage({
- success: function(res) {
- var tempFilePaths = res.tempFilePaths;//这里是选好的图片的地址,是一个数组
- }
- })
然后在app.js中写一个多张图片上传的方法,后面引入,你也可以写在一个JS文件中,后面引入:
- //多张图片上传
- function uploadimg(data){
- var that=this,
- i=data.i?data.i:0,//当前上传的哪张图片
- success=data.success?data.success:0,//上传成功的个数
- fail=data.fail?data.fail:0;//上传失败的个数
- wx.uploadFile({
- url: data.url,
- filePath: data.path[i],
- name: 'file',//这里根据自己的实际情况改
- formData:null,//这里是上传图片时一起上传的数据
- success: (resp) => {
- success++;//图片上传成功,图片上传成功的变量+1
- console.log(resp)
- console.log(i);
- //这里可能有BUG,失败也会执行这里,所以这里应该是后台返回过来的状态码为成功时,这里的success才+1
- },
- fail: (res) => {
- fail++;//图片上传失败,图片上传失败的变量+1
- console.log('fail:'+i+"fail:"+fail);
- },
- complete: () => {
- console.log(i);
- i++;//这个图片执行完上传后,开始上传下一张
- if(i==data.path.length){ //当图片传完时,停止调用
- console.log('执行完毕');
- console.log('成功:'+success+" 失败:"+fail);
- }else{//若图片还没有传完,则继续调用函数
- console.log(i);
- data.i=i;
- data.success=success;
- data.fail=fail;
- that.uploadimg(data);
- }
- }
- });
- }
多张图片上传的方法写好了,下面就是引用:
- var app=getApp();
- Page({
- data:{
- pics:[]
- },
- choose:function(){//这里是选取图片的方法
- var that=this,
pics=this.data.pics;- wx.chooseImage({
- count: 9-pics.length, // 最多可以选择的图片张数,默认9
- sizeType: ['original', 'compressed'], // original 原图,compressed 压缩图,默认二者都有
- sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
- success: function(res){
- var imgsrc=res.tempFilePaths;
pics=pics.concat(imgsrc);- that.setData({
- pics:pics
- });
- },
- fail: function() {
- // fail
- },
- complete: function() {
- // complete
- }
- })
- },
- uploadimg:function(){//这里触发图片上传的方法
- var pics=this.data.pics;
- app.uploadimg({
- url:'https://........',//这里是你图片上传的接口
- path:pics//这里是选取的图片的地址数组
- });
- },
- onLoad:function(options){
- }
- })
刚好写了一个node上传图片代码,亲测可以使用,
或
一个简单的PHP接收代码:
- <?php
- $imgname = $_FILES['file']['name'];
- $tmp = $_FILES['file']['tmp_name'];
- $filepath = 'now/';//记得要自己创建这个文件夹
- if(move_uploaded_file($tmp,$filepath.$imgname.".png")){
- echo "上传成功";
- }else{
- echo "上传失败";
- }
- ?>
完结。
想了解更多的小程序的知识请添加微信小程序开发交流群:368506119
微信小程序多张图片上传的更多相关文章
- [转]微信小程序实现图片上传功能
本文转自:http://blog.csdn.net/feter1992/article/details/77877659 前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何 ...
- nodeJs实现微信小程序的图片上传
今天我来介绍一下nodejs如何实现保存微信小程序传过来的图片及其返回 首先wx.uploadFile绝大部分时候是配合wx.chooseImage一起出现的,毕竟选择好了图片,再统一上传是实现用户图 ...
- 微信小程序实现图片上传功能
前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何实现上传图片到自己的服务器上 前端代码 data: { productInfo: {} }, //添加Banner bin ...
- 微信小程序--实现图片上传
前端: 微信开发者工具 后端:.Net 服务器:阿里云 这里介绍微信小程序如何实现上传图片到自己的服务器上 前端代码 data: { productInfo: {} }, //添加Banner bin ...
- 微信小程序中图片上传阿里云Oss
本人今年6月份毕业,最近刚在上海一家小公司实习,做微信小程序开发.最近工作遇到一个小问题. 微信小程序图片上传阿里云服务器Oss也折腾了蛮久才解决的,所以特意去记录一下. 第一步:配置阿里云地址: 我 ...
- [组件封装]微信小程序-图片批量上传照片墙
描述 批量上传图片, 可设置最大上传个数, 可删除, 可设置默认值. 效果 源码 pictures-wall.wxml <view class="picturesWall"& ...
- 微信小程序 多图上传解决方案
为了使代码体积小 我这里将多图上传 封装到单独的一个js 页面的js调用他 我们看firhealth.js文件内容 // pages/home/home.js var upload = requir ...
- 微信小程序实现图片上传,预览,删除
wxml: <view class='imgBox'> <image class='imgList' wx:for="{{imgs}}" wx:for-item= ...
- 微信小程序wx.uploadFile 上传文件 的两个坑
fileUpload: function (tempFilePath) { var that = this;//坑1: this需要这么处理 wx.uploadFile({ url: url地址, / ...
随机推荐
- java多线程基本概述(五)——线程通信
线程之间的通信可以通过共享内存变量的方式进行相互通信,也可以使用api提供的wait(),notify()实现线程之间的通信.wait()方法是Object类的方法,改方法用来将当前的线程置入&quo ...
- Android -- 带你从源码角度领悟Dagger2入门到放弃
1,以前的博客也写了两篇关于Dagger2,但是感觉自己使用的时候还是云里雾里的,更不谈各位来看博客的同学了,所以今天打算和大家再一次的入坑试试,最后一次了,保证最后一次了. 2,接入项目 在项目的G ...
- 【Java】大文本字符串滤重的简单方案~
本文章也同步至本人的CSDN博客中: http://blog.csdn.net/u012881584/article/details/70477832 今天来说一个Java中处理大文本字符串虑重的两个 ...
- 【uwp】浅谈China Daily中数据同步到One Drive的实现
新版China Daily与旧版相比新增了数据同步的功能,那这个功能具体是如何实现的呢,现在让我们来一起看看. 1.注册应用 开发者中心的应用注册就不用多说了(https://developer.mi ...
- HTTP笔记
"你知道当我们在网页浏览器(Web browser)的地址栏中输入 URL 时,Web 页面是如何呈现的吗?" HTTP协议 HTTP协议(HyperText Transfer P ...
- SpringMVC结合ajaxfileupload文件无刷新上传
jQuery没有提供ajax的文件上传,我们可以通过ajaxfileupload实现ajax文件的上传.其实ajaxfileupload文件上传特别的简单.下面就演示一下在SpringMVC中实现aj ...
- PHP获取Post的原始数据方法小结(POST无变量名)
From : http://blog.csdn.net/hotdigger/article/details/6456240 一般我们都用$_POST或$_REQUEST两个预定义变量来接收POST ...
- 在myeclipse下安装svn插件,出现了Could not generate DH keypair,这么一个错误。
解决方法: window-->preferences-->Team-->SVN-->SVN接口 选择:JavaHL 去https://sliksvn.com/download/ ...
- Nginx 常用配置整理
#定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_processes 8; #全局错误日志定义类型,[ debug | ...
- session与cookie-----2017-05-08
会话控制:目的是记录不同用户身份. 1.session:有实效性 特点: (1)存在在服务器 (2)每个用户都会存一份 (3)可以存储任意类型的数据 优点:安全性高 缺点:服务器压力过大 2.cook ...