网络直播平台搭建,瀑布流布局完美解决方案

网络直播平台搭建,瀑布流布局完美解决方案

使用教程

直接复制代码 列表布局数据自己写

复制代码
<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项目中使用都兼容

以上就是网络直播平台搭建,瀑布流布局完美解决方案, 更多内容欢迎关注之后的文章

 

posted @   云豹科技-苏凌霄  阅读(15)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 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 实现传送带特效
点击右上角即可分享
微信分享提示