小程序多图转base64上传

小程序的多图上传我之前的文章写过。

原理是直接用 wx.chooseImage 1.选择图片,2.微信把图片变成本地图,3.你拿这个本地路径给接口,接口给你张网络图路径。

最近遇见一个需求是为了省服务器空间和带宽,需要把本地图转成base64再传给接口(下图是接口文档)。网上找了很多多图转base64,都是废话。所以自己写一个。老规矩,拿来可以直接用。

 

效果图:

代码:

<view class="weui-cell">
    <view class="weui-cell__bd">
        <view class="weui-uploader">
            <view class="weui-uploader__hd">
                <view class="weui-uploader__title">上传图片:<text>(最多上传3张)</text></view>
            </view>
            <view class="weui-uploader__bd">
                <view class="weui-uploader__files">
                    <block wx:for="{{pics}}" wx:key="pics" wx:for-item="image">
                        <view class="weui-uploader__file">
                            <image class="weui-uploader__img" src="{{image}}" src="{{image}}" bindtap="previewImage"></image>
                            <view class='closex' bindtap='deleteImg' data-index='{{index}}'>X</view>
                        </view>
                    </block>
                    <!-- 加号 -->
                    <view class="weui-uploader__input-box {{isShow?'true':'hideTrue'}}">
                    <view class="weui-uploader__input" bindtap="chooseImage"></view>
                     </view>
                    <!-- 加号 -->
                </view>
                <view class="delete-btn" data-index="{{index}}" catchtap="deleteImg"></view>
                <!-- isShow 这个是判断是否进行触发点隐藏操作 -->
                
            </view>
        </view>
    </view>
</view>
/* add img */

icon {
  vertical-align: middle;
}

.weui-cell {
  padding: 10px 15px;
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  align-items: center;
}

.weui-cell_input {
  padding-top: 0;
  padding-bottom: 0;
}

.weui-uploader__hd {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  padding-bottom: 10px;
  align-items: center;
}

.weui-uploader__title {
  flex: 1;
}

.weui-uploader__title text {
  color: #b2b2b2;
}

.weui-uploader__bd {
  margin-bottom: -4px;
  margin-right: -9px;
  overflow: hidden;
}

.weui-uploader__file {
  float: left;
  margin-right: 9rpx;
  margin-bottom: 9rpx;
  position: relative;
}

.weui-uploader__img {
  display: block;
  width: 120rpx;
  height: 120rpx;
}

.weui-uploader__input-box {
  float: left;
  position: relative;
  margin-right: 10rpx;
  width: 120rpx;
  height: 120rpx;
  box-sizing: border-box;
  border: 1rpx solid #d9d9d9;
}

.weui-uploader__input-box:before, .weui-uploader__input-box:after {
  content: " ";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #d9d9d9;
}

.weui-uploader__input-box:before {
  width: 2px;
  height: 39.5px;
}

.weui-uploader__input-box:after {
  width: 39.5px;
  height: 2px;
}

.weui-uploader__input {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}

.hideTrue {
  display: none;
}

.closex {
  width: 40rpx;
  height: 40rpx;
  text-align: center;
  line-height: 40rpx;
  position: absolute;
  right: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
}

js:DATA里需要写这4个参数,我就不给大家贴了。直接从点击上传开始写了就。我的需求是最多传3张,有6张,9张需求的,自己改。第10行,接着写4,5,6 就行。最终的  pics  就是base64数组。 大家可以conlse.log()打印一下、

// 图片上传
  chooseImage: function () {
    var _this = this,
      pics = this.data.pics;
    wx.chooseImage({
      count: 3 - pics.length, // 最多可以选择的图片张数,默认9
      sizeType: ['compressed'], // original 原图,compressed 压缩图,默认二者都有
      sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
      success: res => {
      for (var p = 0; p < res.tempFilePaths.length; p++) {
        wx.getFileSystemManager().readFile({
          filePath: res.tempFilePaths[p], //选择图片返回的相对路径
          encoding: 'base64', //编码格式
          success: res => { //成功的回调
            var imgSrc = 'data:image/png;base64,' + res.data;
            pics = pics.concat(imgSrc);
            console.log('th++',pics)
            //   // 控制触发添加图片的最多时隐藏
            if (pics.length >= 3) {
              _this.setData({
                isShow: (!_this.data.isShow)
              })
            } else {
              _this.setData({
                isShow: (_this.data.isShow)
              })
            }
            _this.setData({
              pics: pics,
            })
          }
        })
        }
      },
      fail: function () {
        // fail
      },
      complete: function () {
        // complete
      }
    })
  },

  // 图片预览
  previewImage: function (e) {
    var current = e.target.dataset.src
    wx.previewImage({
      current: current,
      urls: this.data.pics
    })
  },

 // 删除图片
 deleteImg: function (e) {
   var _this = this;
  //  var imgs = this.data.imgs;
   var pics = this.data.pics;
    var index = e.currentTarget.dataset.index;
   pics.splice(index, 1);
    this.setData({
      pics: pics,
    });
   if (pics.length >= 3) {
     _this.setData({
       isShow:false
     })
   } else {
     _this.setData({
       isShow: true
     })
   }
  },

有什么不会的可以直接呼我。。。有啥可以为大家解答。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值