共计 1862 个字符,预计需要花费 5 分钟才能阅读完成。
预览图
应用教程
间接复制代码 <hd-list/> 列表布局数据本人写
<template>
<view class="waterfall-wrap">
<view class="waterfall-list">
<view class="left">
<hd-list
:listData="item"
v-for="(item,index) in goodsLeftList"
:key="index"
@onImageLoad="onImageLoad"
></hd-list>
</view>
<view class="right">
<hd-list
:listData="item"
v-for="(item,index) in goodsRightList"
:key="index"
@onImageLoad="onImageLoad"
></hd-list>
</view>
</view>
</view>
</template>
<script>
import hdList from "../component/hd-list.vue";
export default {
name: "waterfall",
props: {
listData: {
type: Array,
default: []}
},
components: {hdList},
watch: {
/**
* 监听 listData 数据
*/
listData: {handler: function(data) {data.length > 0 && this.waterfallImage();
},
immediate: true
}
},
data() {
return {
goodsListCount: 0, // 加载第 i 张图片
// 左侧商品列表
goodsLeftList: [],
goodsLeftListHeight: 0,
// 右侧商品列表
goodsRightList: [],
goodsRightListHeight: 0
};
},
methods: {
// 图片绑定事件,通过比拟左右列表高度,实现瀑布流展现
onImageLoad: function(e) {
let divWidth = 342; // 显示的单栏宽度,我设为 342rpx
let oImgW = e.detail.width; // 图片原始宽度
let oImgH = e.detail.height; // 图片原始高度
let rImgH = (divWidth * oImgH) / oImgW + 32; // 依据宽高比计算以后载入的图片的高度
if (this.goodsListCount == 0) {
this.goodsLeftListHeight += rImgH; // 第一张图片高度加到 goodsLeftListHeight
this.goodsListCount++; // 图片索引加 1
this.goodsRightList.push(this.listData[this.goodsListCount]); // 增加第二张图片到 goodsRightList 数组,因为第一张曾经初始化到左侧列表中
} else {
this.goodsListCount++; // 图片索引加 1
if (this.goodsLeftListHeight > this.goodsRightListHeight) {
// 把图片的高度加到目前高度更低的栏中
this.goodsRightListHeight += rImgH; // 第二张图片高度加到 goodsRightListHeight
} else {this.goodsLeftListHeight += rImgH;}
if (this.goodsListCount < this.listData.length) {
// 依据目前的栏高,把下一张图片,push 到低的那栏
if (this.goodsLeftListHeight > this.goodsRightListHeight) {this.goodsRightList.push(this.listData[this.goodsListCount]);
} else {this.goodsLeftList.push(this.listData[this.goodsListCount]);
}
}
}
},
// 向商品列表增加第一张图片
async waterfallImage() {
this.goodsListCount = 0;
this.goodsLeftList.push(this.listData[0]);
}
}
};
</script>
兼容性
uni-app 我的项目中应用都兼容
欢送关注
欢送关注小程序“进阶的大前端”,800 多道前端面试题在线查看
正文完