上传图片并保存至云存储再存入数据库,并实时显示图片

  1. 云开发控制台的数据库里创建好集合articles
  2. index.wxml:
//这里处理为一个轮播图,实时轮播出artcles数据库中的图片
<swiper indicator-dots="{{indicatorDots}}" 
  autoplay="{{autoplay}}" interval="{{interval}}" 
  duration="{{duration}}">
    <block wx:for="{{imgUrls}}">
      <swiper-item>
        <image src="{{item}}" class="slide-image" width="100%" height="100%" />
      </swiper-item>
    </block>
  </swiper>
  <!-- 上传图片 -->
  <view class="uploader">
    <view class="uploader-text" bindtap="doUpload">
      <text>上传图片</text>
    </view>
    <view class="uploader-container" wx:if="{{imgUrl}}">
      <image class="uploader-image" src="{{imgUrl}}" mode="aspectFit" bindtap="previewImg"></image>
    </view>
  </view>
  1. index.js:
data:{
     userInfo: {},
    indicatorDots: true,
    autoplay: true,
    interval: 5000,
    duration: 1000,
    imgUrls: [],
    openid: ''
},
onload: function(){
 		const that = this
      const db = wx.cloud.database()
      // 查询当前用户所有的 articles
      let _arr = []
      db.collection('articles').get({
        success: res => {
          var arr = res.data;
          for (var i = 0; i < arr.length; i++) {
            _arr.push(
              arr[i].bigImg
            )

          }
          this.setData({
            imgUrls: _arr
            })
          console.log('[数据库] [查询记录] 成功: ', res.data)
            
        },
        fail: err => {
          wx.showToast({
            icon: 'none',
            title: '查询记录失败'
          })
          console.error('[数据库] [查询记录] 失败:', err)
        }
      })
},
// 上传图片
  doUpload: function () {
    let _this = this;
    // 选择图片
    wx.chooseImage({
      sizeType: ['compressed'],
      sourceType: ['album', 'camera'],
      success: function (res) {
        wx.showLoading({
          title: '上传中',
        })

        const filePath = res.tempFilePaths[0]
        console.log(filePath )

		//给上传图片设置好存储路径
        const name = Math.random() * 1000000;
        console.log(name) 
        const cloudPath = name + filePath.match(/\.[^.]+?$/)[0] //存储路径名
        wx.cloud.uploadFile({
          cloudPath,
          filePath,
          success: res => {
            let fileID = res.fileID;
            console.log('[上传文件] 成功:', fileID)
            

			//将成功上传的图片存入artcles数据库中
            const db = wx.cloud.database();
		
            db.collection("articles").add({
              data: {
                bigImg: fileID
              },
             
              success: function () {
                //添加成功后更新imgurls,即能够在页面中显示新添加的图片
                _this.data.imgUrls.push(fileID);
                _this.setData({     imgUrls: _this.data.imgUrls
                });
               
                wx.showToast({
                  title: '图片存储成功',
                  'icon': 'none',
                  duration: 3000
                }),
                  console.log("255");
              },
              fail: function () {
                wx.showToast({
                  title: '图片存储失败',
                  'icon': 'none',
                  duration: 3000
                })
              }
            });            
          },
          fail: e => {
            console.error('[上传文件] 失败:', e)
          },
          complete: () => {
            wx.hideLoading()
          }
        })

      },
      fail: e => {
        console.error(e)
      }
    })
  },

你可能感兴趣的:(小程序学习之路)