网络直播平台搭建,瀑布流布局完美解决方案
网络直播平台搭建,瀑布流布局完美解决方案
使用教程
直接复制代码 列表布局数据自己写
<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项目中使用都兼容
以上就是网络直播平台搭建,瀑布流布局完美解决方案, 更多内容欢迎关注之后的文章
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
2023-08-24 直播源码开发,Android判断网络是否可用
2023-08-24 直播商城源码,JS Date配置日期格式化
2023-08-24 直播系统开发,springboot指定时间触发定时任务
2022-08-24 直播网站程序源码,清除app data以及获取图标
2022-08-24 直播网站源码,Launcher3 删除主页搜索框
2022-08-24 直播电商平台开发,android cardview 取消阴影,高度
2021-08-24 小视频app源码Android OpenGL ES 实现传送带特效