赞
踩
直接上干货
第一部分为结构
- <swiper class="list" :current='index' @change="swiperchange" @scrolltolower="onReachBottom">
- <swiper-item style="overflow: scroll;" v-for="(item,index) in 2" :key="index">
- <view v-for="(item,index) in list " class="list_item" :style="{'--top2':item.top+'px','--left':item.left}">
- <view class="" style="background: rgba(0, 0, 0, 0.5);">
- <view class="">
- <!-- <image class="fm" src="https://api.ccttiot.com/smartmeter/img/static/uGUX2rY4w3ZPvRhrKpWw" mode=""> -->
- <image class="fm" :src="item.url" mode="widthFix"></image>
- </view>
- <view class="wz">
- <view class="title">
- 的故事吧概念啊啊啊啊啊啊啊
- </view>
- <view class="xx">
- <image class="tx" src="https://api.ccttiot.com/smartmeter/img/static/u8HN5WcA04XMKLsMnr2P"
- mode=""></image>
- <view class="username">
- 皮蛋瘦肉...
- </view>
- <image class="sc" src="https://api.ccttiot.com/smartmeter/img/static/uQJ3tBEKEmeC4jexhNgK"
- mode=""></image>
- <view class="dz">
- 3056
- </view>
- </view>
- </view>
- </view>
- <view class="kong" style="width: 100%;height: 20rpx;background-color: transparent;"></view>
- </view>
- </swiper-item>
- </swiper>
-
-
第二部分为样式
.list { width: 100%; margin-top: 36rpx; display: flex; justify-content: space-between; padding-right: 36rpx; flex-wrap: wrap; height: 80vh; overflow: scroll; box-sizing: border-box; position: relative; .list_item:last-of-type{ padding-bottom: 200rpx; } .list_item { width: 326rpx; box-sizing: border-box; margin-top: 22rpx; overflow: hidden; margin-left: 34rpx; break-inside: avoid; position: absolute; // 设置为变量 top: var(--top2); left: var(--left); .fm { width: 100%; height: 326rpx; border-radius: 10rpx; object-fit: cover; } .wz { padding: 18rpx 16rpx; padding-top: 0 !important; box-sizing: border-box; .title { font-size: 28rpx; color: #FFFFFF; margin-top: 10rpx; text-align: left; } .xx { display: flex; margin-top: 12rpx; align-items: center; .tx { width: 32rpx; height: 32rpx; border-radius: 50%; margin-right: 10rpx; } .username { font-size: 24rpx; color: #FFFFFF; margin-right: 16rpx; } .sc { width: 25rpx; height: 24rpx; margin-right: 8rpx; } .dz { font-size: 24rpx; color: #FFFFFF; } } } } }
第三部分为js部分
- export default {
- data() {
- return {
- AllData: [],
- leftHeight: 0,
- rightHeight: 0,
- list: [{
- url: "https://api.ccttiot.com/smartmeter/img/static/ur3ZXP3az10GilTm9nOV",
- left: "50%",
- top: "0",
- }, {
- url: "https://api.ccttiot.com/smartmeter/img/static/uFo3Rj5OC6S3h0RNaZqf",
- left: "50%",
- top: "0",
- }, {
- url: "https://api.ccttiot.com/smartmeter/img/static/ur3ZXP3az10GilTm9nOV",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/u8HN5WcA04XMKLsMnr2P",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/uZQmeK9Fp2oHAnu3Yc3U",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/uGUX2rY4w3ZPvRhrKpWw",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/uZQmeK9Fp2oHAnu3Yc3U",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/u8HN5WcA04XMKLsMnr2P",
- left: "50%",
- top: "0",
- },
- {
- url: "https://api.ccttiot.com/smartmeter/img/static/uFo3Rj5OC6S3h0RNaZqf",
- left: "50%",
- top: "0",
- },
- ],
-
-
- }
- },
- onLoad() {
- //在页面一开始就获取数据进行操作
- setTimeout(() => {
- uni.createSelectorQuery().selectAll('.list_item').boundingClientRect(data => {
- data.forEach((item) => {
- this.AllData.push(item.height)
- })
- for (let i = 0; i < this.AllData.length; i++) {
- // 判断赋值
- if (this.rightHeight < this.leftHeight) {
- // 设置位置
- this.list[i].left = '50%'
- // 先进行赋值
- this.list[i].top = this.rightHeight
- // 再进行累加
- this.rightHeight += this.AllData[i]
- } else {
- this.list[i].left = 0
- this.list[i].top = this.leftHeight
- this.leftHeight += this.AllData[i]
- }
- }
- }).exec()
- }, 500)
- },
- methods: {
- swiperchange(e){
- console.log(e.target.current);
- this.index = e.target.current
- },
- }
- }
- </script>
最后附上效果图 当中我所使用的图片均为线上图片
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。