微信小程序实现多张照片上传

这篇具有很好参考价值的文章主要介绍了微信小程序实现多张照片上传。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

个人介绍

hello hello~ ,这里是 code袁~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹
微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传
🦁作者简介:一名喜欢分享和记录学习的在校大学生
💥个人主页:code袁
💥 个人QQ:2647996100
🐯 个人wechat:code8896

专栏导航

code袁系列专栏导航
1.毕业设计与课程设计:本专栏分享一些毕业设计的源码以及项目成果。🥰🥰🥰
2.微信小程序开发:本专栏从基础到入门的一系开发流程,并且分享了自己在开发中遇到的一系列问题。🤹🤹🤹
3.vue开发系列全程线路:本专栏分享自己的vue的学习历程。

非常期待和您一起在这个小小的互联网世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨ 

微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传

1.功能实现

当选择图片后,生成对象tempFilePaths文件路径。在通过for循环依次的图片的src上传到服务器。当服务器的状态码为200且图片上传完毕后将图片的src转化为Json字符串存在数组中以便将其添加到数据库

2.代码实现

1.mp-uploader

<view class="page">
    <view class="page__bd">
        <mp-cells>
            <mp-cell>
                <mp-uploader select="{{selectFile}}" upload="{{uplaodFile}}" files="{{files}}" max-count="4" title="附件上传" tips="最多可上传4张照片"></mp-uploader>
            </mp-cell>
        </mp-cells>
    </view>
</view>
//data中
 this.setData({ 
            selectFile: this.selectFile.bind(this),
            uplaodFile: this.uplaodFile.bind(this)
        })
 uplaodFile(files) {
        console.log('upload files', files)
        console.log('upload files', files)
        // 文件上传的函数,返回一个promise
        return new Promise((resolve, reject) => {
          const tempFilePaths = files.tempFilePaths;
          //上传返回值
          const that = this;
          const object = {};
          for (var i = 0; i < tempFilePaths.length; i++) {
            let filePath = tempFilePaths[i]
            wx.uploadFile({
                filePath: filePath,
                name: 'file',
                url: 'http://localhost:3000/upload/upload',
                success: function(res){
                    console.log('444',res.statusCode)
                    if (res.statusCode=== 200 ) {
                        const url = JSON.parse(res.data).url
                        that.data.files.push(url)
                        if (that.data.files.length === tempFilePaths.length) {
                          object.urls = that.data.files;
                          resolve(object)  //这就是判断是不是最后一张已经上传了,用来返回,
                        }
                      } else {
                        reject('error')
                      }
                }
              })
          }
          
        })
        // 文件上传的函数,返回一个promise
    },

微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传
微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传

2.chooseImage

<view>
<block wx:for="{{images}}" wx:for-item="src">
  <image  src="{{src}}"></image>           
</block>
<view bindtap="upload">上传</view>

upload(){
    let that = this;
    wx.chooseImage({//异步方法
        count: 9,//最多选择图片数量
        sizeType: ['original', 'compressed'],//选择的图片尺寸 原图,压缩图
        sourceType: ['album', 'camera'],//相册选图,相机拍照
        success(res) {
            //tempFilePaths可以作为图片标签src属性
            const tempFilePaths = res.tempFilePaths
            console.log("选择成功", res)

            for (let i = 0; i < tempFilePaths.length; i++) {//多个图片的循环上传
                wx.cloud.uploadFile({//上传至微信云存储
                    cloudPath: 'myImage/' + new Date().getTime() + "_" + Math.floor(Math.random() * 1000) + ".jpg",//使用时间戳加随机数作为上传至云端的图片名称
                    filePath: tempFilePaths[i],// 本地文件路径
                    success: res => {
                        // 返回文件 ID
                        console.log("上传成功", res.fileID)
                        that.setData({
                            images: res.fileID//获取上传云端的图片在页面上显示
                        })
                        wx.showToast({
                            title: '上传成功',
                        })
                    }
                })
            }

        }
    })
}

3.页面展示

图片的src在数据库中是以字符串的形式存储。当需要展示时我们只需要将字符串转化为数组对象即可
原始数据 “http://localhost:3000/images/17112466754606371.jpg”,“http://localhost:3000/images/17112466755133666.jpg”,“http://localhost:3000/images/17112466756494564.jpg”]

 getShare().then(res=>{
        const list=res.data
         list.forEach(obj => {
            console.log('8888',obj.img)
         const imgString = obj.img;
         const trimmedString = imgString.replace('["', '').replace('\"]', '');
         const imgArray = trimmedString.split('"\,\"');
         console.log('444',imgArray)
         obj.img = imgArray;
        })
        this.setData({
            shareList:list
        })
       })

微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传

🎉写在最后

🍻伙伴们,如果你已经看到了这里,觉得这篇文章有帮助到你的话不妨点赞👍或 Star ✨支持一下哦!手动码字,如有错误,欢迎在评论区指正💬~

你的支持就是我更新的最大动力💪~
微信小程序实现多张照片异步上传,微信小程序开发,微信小程序,小程序,图片上传文章来源地址https://www.toymoban.com/news/detail-845668.html

到了这里,关于微信小程序实现多张照片上传的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 微信小程序智慧流调微信小程序设计与实现

    摘 要 自从2020年新冠疫情爆发以来,对全国人民的健康和全国各地区的经济发展都带来了很大的影响,并且新冠肺炎对各个领域带来的影响还未完全消除。近三年以来,全国各地区多次爆发新的疫情,导致许多人被隔离,也导致全国各阶段的学生都需要在家中上网课,对学生

    2024年02月11日
    浏览(32)
  • 微信小程序在线阅读系统微信小程序设计与实现

    摘 要:信息技术永远是改变生活的第一种创新方式,各种行业的发展更是脱离不了科技化的支持。原本传统的行业正在被科技行业的切入悄悄的发生变化。就拿我们生活当中常见的事情举例而言,在外卖行业还没有发展的快速的时候,方便面等速食成了快速吃饱的首要选择,

    2024年02月10日
    浏览(29)
  • 基于微信小程序的校园导航小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项

    2024年02月19日
    浏览(29)
  • 基于微信小程序的智慧农业小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项

    2024年02月20日
    浏览(27)
  • 基于微信小程序的客运售票小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及

    2024年02月04日
    浏览(32)
  • 基于微信小程序的社区团购小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕设精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文

    2024年02月03日
    浏览(39)
  • 基于微信小程序的跑步运动计划小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例(持续更新) 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及

    2024年01月23日
    浏览(26)
  • 微信小程序——异步请求使用async/await实现同步

            在小程序的开发中,我们知道网络请求wx.requset是一个异步请求的API,当我们使用它时,会出现请求还没有结束,我们下面写的处理数据的代码就已经执行了从而导致了我们写的程序出现问题,那么我们该怎么解决这个问题呢?今天我们用async/await来实现一下吧。

    2024年02月11日
    浏览(30)
  • 微信小程序开发|基于微信小程序的健身陪练系统的设计与实现

    作者主页:编程指南针 作者简介:Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、腾讯课堂常驻讲师 主要内容:Java项目、Python项目、前端项目、人工智能与大数据、简历模板、学习资料、面试题库

    2024年02月12日
    浏览(27)
  • 基于微信小程序的校园生活服务小程序设计与实现

    💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/华为云/阿里云等平台优质作者。 👇🏻 精彩专栏 推荐订阅👇🏻 计算机毕业设计精品项目案例-200套 🌟 文末获取源码+数据库+文档 🌟 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编

    2024年02月20日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包