小程序如何实现多图上传、图片预览效果?(代码示例)

前端之家收集整理的这篇文章主要介绍了小程序如何实现多图上传、图片预览效果?(代码示例)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本篇文章给大家带来的内容是介绍小程序如何实现多图上传图片预览效果?(代码示例) 。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

wxml代码

    
    
      
        点击可预览选好的图片
        {{pics.length}}/9
      
      
        
          
            
              
            
          
        
        
        
          @H_502_27@
        
      
    
  

wxss代码

page {
  line-height: 1.6;
  font-family: -apple-system-font,"Helvetica Neue",sans-serif;
}
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__info {
  color: #b2b2b2;
}
.weui-uploader__bd {
  margin-bottom: -4px;
  margin-right: -9px;
  overflow: hidden;
}
.weui-uploader__file {
  float: left;
  margin-right: 9px;
  margin-bottom: 9px;
}
.weui-uploader__img {
  display: block;
  width: 79px;
  height: 79px;
}
.weui-uploader__input-Box {
  float: left;
  position: relative;
  margin-right: 9px;
  margin-bottom: 9px;
  width: 77px;
  height: 77px;
  border: 1px 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
}

js代码

var app = getApp();
Page({
data: {
pics: [],count: [1,2,3,4,5,6,7,8,9],isShow: true
},onLoad: function (options) {
// 生命周期函数--监听页面加载
isShow: (options.isShow == "true" ? true : false)
},// 图片上传
chooseImage: function () {
var _this = this,pics = this.data.pics;
wx.chooseImage({
count: 9 - pics.length,// 最多可以选择的图片张数,默认9
sizeType: ['original','compressed'],// original 原图,compressed 压缩图,默认二者都有
sourceType: ['album','camera'],// album 从相册选图,camera 使用相机,默认二者都有
success: function (res) {
// success
var imgSrc = res.tempFilePaths; //图片路径
pics = pics.concat(imgSrc); //选取的图片的地址数组
// 控制触发添加图片的最多时隐藏
if (pics.length >= 9) {
_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 imgs = this.data.imgs;
var index = e.currentTarget.dataset.index;
imgs.splice(index,1);
this.setData({
imgs: imgs
});
},uploadimg:function(){//这里触发图片上传方法
var pics=this.data.pics;
app.uploadimg({
url:'https://........',//这里是你图片上传的接口
path:pics//这里是选取的图片的地址数组
});
},})

在app.js中写一个多张图片上传方法,后面引入,你也可以写在一个JS文件中,后面引入:

//多张图片上传
function uploadimg(data){
var that=this,i=data.i?data.i:0,//当前上传的哪张图片
success=data.success?data.success:0,//上传成功的个数
fail=data.fail?data.fail:0;//上传失败的个数
wx.uploadFile({
url: data.url,filePath: data.path[i],name: 'file',//这里根据自己的实际情况改
formData:null,//这里是上传图片时一起上传的数据
success: (resp) => {
success++;//图片上传成功,图片上传成功的变量+1
console.log(resp)
console.log(i);
//这里可能有BUG,失败也会执行这里,所以这里应该是后台返回过来的状态码为成功时,这里的success才+1
},fail: (res) => {
fail++;//图片上传失败,图片上传失败的变量+1
console.log('fail:'+i+"fail:"+fail);
},complete: () => {
console.log(i);
i++;//这个图片执行完上传后,开始上传下一张
if(i==data.path.length){ //当图片传完时,停止调用
console.log('执行完毕');
console.log('成功:'+success+" 失败:"+fail);
}else{//若图片还没有传完,则继续调用函数
console.log(i);
data.i=i;
data.success=success;
data.fail=fail;
that.uploadimg(data);
}

        }
    });
}</pre><p><a href="/tag/xiaoguo/" target="_blank" class="keywords">效果</a>图,可点击放大预览:</p><p ><p class="pic_center"><img src="/res/2019/01-08/21/031b1fc3967eb21d501be9959c8c29a9.png"&gt;</p></p><p>总结:以上就是本篇<a href="/tag/wenzhang/" target="_blank" class="keywords">文章</a>的全部<a href="/tag/neirong/" target="_blank" class="keywords">内容</a>,希望能对大家的学习有所帮助。

猜你在找的微信小程序相关文章