首页 > 微信 > 详细

微信小程序瀑布流布局

时间:2021-08-24 16:48:42      阅读:35      评论:0      收藏:0      [点我收藏+]

wxml文件

<view class="container">
  <view class="left-item">
    <view class="item"></view>
  </view>
   <view class="right-item">
    <view class="item"></view>
  </view>
</view>

js文件

let leftHeight = 0, rightHeight = 0; //分别定义左右两边的高度
let query;

page({
   data:{
      list: [],    //通过接口获取的数组
      leftList:[],     //左边数组
      rightList:[],    //右边数组
   },

   //瀑布流布局
  async waterfallFlow(){      //在获取list后调用
    const {list,leftList,rightList} =this.data;
    query = wx.createSelectorQuery();
    for (const item of list) {
      leftHeight <= rightHeight ? leftList.push(item) : rightList.push(item); //判断两边高度,来觉得添加到那边
      await this.getBoxHeight(leftList, rightList);
     }

  },
  getBoxHeight(leftList,rightList){
    return new Promise((resolve,reject)=>{
      this.setData({ leftList, rightList });
      query.select(‘.left-item‘).boundingClientRect();
      query.select(‘.right-item‘).boundingClientRect();
      query.exec((res) => {
       leftHeight = res[0].height; //获取左边列表的高度
       rightHeight = res[1].height; //获取右边列表的高度
       resolve();
      });
    })
  },

})

样式文件根据自己项目的样式来,主要分为两列。

 

总结,将样式分为两列,循化数据,获取两列的高度,根据判断条件将两个数组中的每个数据放入左右数组之中

 

微信小程序瀑布流布局

原文:https://www.cnblogs.com/sisxxw/p/15180320.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!