小程序之批量上传图片

上传图片在项目中属于一个常见场景。在小程序中同样遇到了这样的需求。如何去解决呢?
利用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

  /*
   *   批量上传函数
   *   @params {*} params 上传入参对象
   *   @params {Function} callbackFn 循环回调函数
   *   @params {Function} successFn 成功回调函数
   */

 const batchUpload = (params,callBack,successFn) => {
     if(!params.uploadUrl) {
        console.log('请传入上传地址')
        return
     }
     if(!(params.imgPaths instanceof Array)) {
        console.log('请传入array类型')
        return
     } // 校验传入是否为数组
     let maxLength = params.imgPaths.length // 传入数组长度
     let i = params.subscript?params.subscript:0 // 当前上传图片下标
     let successNum = params.successNum?params.successNum:0 // 上传成功数
     let failNum = params.failNum?params.failNum:0 // 上传失败数
     let resultData = params.resultData?params.resultData:[] //  上传返回的imgUrl
     let endData = {} // 成功回调暴露出去的结果
        wx.uploadFile({
            url: params.uploadUrl,
            filePath: params.imgPaths[i],
            name: 'test_batchUpload',
            headers: {
                "Content-Type": "multipart/form-data"
            },
            formData: {
                // 其它参数
            },
            success(res) { // 返回code为指定结果表示上传成功反之上传失败
                if (res.statusCode == 200) {
                    let data = JSON.parse(res.data)
                    successNum++
                    resultData.push(data.url)
                }else {
                    failNum++
                }
            },
            fail(res) {
                failNum++
            },
            complete() {
                i++
                if(i==maxLength) { // 上传完毕调用成功回调暴露指定数据出去
                    endData = {
                        imgPaths:resultData,
                        successNum:successNum,
                        failNum: failNum,
                    }
                    successFn(endData)
                }else{ // 执行下一张上传
                    params.subscript = i
                    params.successNum = successNum
                    params.failNum = failNum
                    params.resultData = resultData
                    // console.log(_that,'_that')
                    callBack(params,callBack,successFn)
                }
            }
        })
    }
    export {
        batchUpload,
    }

3, 项目中引用

index.js

    import batchUpload form '../util/util.js'
    
    Page({
        data:{
            showImage:[]
        }
        
        uploadImg() {
            let that = this
            wx.chooseImage({
                count: 6,
                success(res) {
                    const tempFilePaths = res.tempFilePaths
                    let file = tempFilePaths[0];
                    let params = {
                        uploadUrl: 'test_url', // 图片上传接口
                        imgPaths: tempFilePaths 
                    }
                    batchUpload(params,batchUpload,(res)=>{
                        let showImage = that.data.showImage
                        showImage = res.imgPaths
                        that.setData({ 
                            showImage
                        },()=>{
                            let msg = '成功上传'+res.successNum+"张,失败"+res.failNum+"张"
                            wx.showToast({
                                title:msg
                            })
                        })
                    })
                }
            })
        }
    })

4,效果图

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

5, 其它

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容