• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

小程序多图转base64上传

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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

原理是直接用 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
     })
   }
  },

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
一图一表一段文字读懂微信小程序的生命周期发布时间:2022-07-18
下一篇:
微信小程序缓存技术发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap