You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
141 lines
4.6 KiB
141 lines
4.6 KiB
1 month ago
|
<template>
|
||
|
<view class="myimgDV">
|
||
|
<view v-if="imgPicList.length>0" class='receiveimage flex justify'>
|
||
|
<block v-for="(item,ind) in imgPicList" :key="ind">
|
||
|
<image class="imgitem" :style="{width:imgwidth,height:imgheight}" :class="imgboxtype==0?'onepic':imgboxtype==1?'doublepic':imgboxtype==2?'triplepic':''"
|
||
|
:src="item" :mode="imgboxtype==0?'widthFix':imgboxtype==1?'aspectFill':imgboxtype==2?'aspectFill':''" @click="previewpic(item,imgPicList)"></image>
|
||
|
<!-- {width:(imgboxtype==0?'':imgwidth),height:(imgboxtype==0?'':imgwidth),padding:(imgboxtype==0?'':imgpad)} -->
|
||
|
</block>
|
||
|
</view>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
export default {
|
||
|
name:"community_image_box",
|
||
|
data() {
|
||
|
return {
|
||
|
imgPicList: [],
|
||
|
imgboxtype: 0,
|
||
|
imgwidth: 0,
|
||
|
imgpad: 0,
|
||
|
imgheight: ''
|
||
|
}
|
||
|
},
|
||
|
props: {
|
||
|
imgList: {
|
||
|
type: Array
|
||
|
},
|
||
|
num: {
|
||
|
type: Number,
|
||
|
default: 0
|
||
|
},
|
||
|
pad: {
|
||
|
type: Number,
|
||
|
default: 0
|
||
|
}
|
||
|
},
|
||
|
methods: {
|
||
|
// 图片预览
|
||
|
previewpic(cind, clist) {
|
||
|
console.log(cind, clist);
|
||
|
uni.previewImage({
|
||
|
urls: clist,
|
||
|
current: cind,
|
||
|
indicator: 'default'
|
||
|
});
|
||
|
},
|
||
|
getheight() {
|
||
|
console.log('imgboxtype:',this.imgboxtype)
|
||
|
let that = this;
|
||
|
const query = uni.createSelectorQuery().in(that)
|
||
|
query.select('.imgitem').boundingClientRect()
|
||
|
query.exec((res)=>{
|
||
|
console.log(res[0].width)
|
||
|
if (that.num == 1) {
|
||
|
that.imgheight = '100%';
|
||
|
} else if (that.num == 2 || that.num == 4) {
|
||
|
that.imgheight = (res[0].width).toFixed(2) + 'px';
|
||
|
} else {
|
||
|
that.imgheight = (res[0].width).toFixed(2) + 'px';
|
||
|
}
|
||
|
})
|
||
|
|
||
|
// const query = uni.createSelectorQuery().in(this).select('.imgitem');
|
||
|
// uni.createSelectorQuery().select('.imgitem').boundingClientRect(res => {
|
||
|
// console.log('reac', res)
|
||
|
// if (this.num == 1) {
|
||
|
// this.imgheight = '100%';
|
||
|
// } else if (this.num == 2 || this.num == 4) {
|
||
|
// this.imgheight = (res.width).toFixed(2) + 'px';
|
||
|
// } else {
|
||
|
// this.imgheight = (res.width).toFixed(2) + 'px';
|
||
|
// }
|
||
|
// }).exec()
|
||
|
|
||
|
}
|
||
|
},
|
||
|
mounted() {
|
||
|
// let this = this;
|
||
|
this.imgPicList = this.imgList;
|
||
|
console.log('num:'+this.num)
|
||
|
if (this.num == 1) {
|
||
|
this.imgboxtype = 0;
|
||
|
this.imgwidth = 100 + '%';
|
||
|
} else if (this.num == 2 || this.num == 4) {
|
||
|
this.imgboxtype = 1;
|
||
|
this.imgwidth = 49 + '%';
|
||
|
} else if (this.num == 3 || this.num > 4) {
|
||
|
this.imgboxtype = 2;
|
||
|
this.imgwidth = 32 + '%';
|
||
|
}
|
||
|
this.$nextTick(function() {
|
||
|
this.getheight();
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss">
|
||
|
.myimgDV {
|
||
|
.flex {
|
||
|
display: flex;
|
||
|
}
|
||
|
.justify {
|
||
|
justify-content: space-between;
|
||
|
}
|
||
|
.receiveimage {
|
||
|
margin-top: 28rpx;
|
||
|
display: flex;
|
||
|
flex-wrap: wrap;
|
||
|
width: 100%;
|
||
|
.onepic {
|
||
|
width: 100%;
|
||
|
// height: 188rpx;
|
||
|
// height: auto;
|
||
|
margin-bottom: 28rpx;
|
||
|
&:nth-child(3n) {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
}
|
||
|
.doublepic {
|
||
|
// width: 340rpx;
|
||
|
// height: 340rpx;
|
||
|
margin-right: 12rpx;
|
||
|
margin-bottom: 12rpx;
|
||
|
&:nth-child(2n) {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
}
|
||
|
.triplepic {
|
||
|
// width: 222rpx;
|
||
|
// height: 222rpx;
|
||
|
margin-right: 12rpx;
|
||
|
margin-bottom: 12rpx;
|
||
|
&:nth-child(3n) {
|
||
|
margin-right: 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</style>
|