網路直播平臺搭建,瀑布流佈局完美解決方案
使用教程
直接複製程式碼 列表佈局資料自己寫
<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專案中使用都相容
以上就是網路直播平臺搭建,瀑布流佈局完美解決方案, 更多內容歡迎關注之後的文章