微信小程序瀑布流之两列瀑布流

效果图

wxml代码

<scroll-view scroll-y="true" bindscrolltolower="loadImages" >


<view class="bottom">
<view class="bottom_z">

<view id="left">
<view class="left"  wx:for="{{leftList}}" wx:key>
/*  注意图片标签里边添加 mode="widthFix"   */
/*你的卡片代码*/
</view>
</view>

<view id="right">
<view class="right"  wx:for="{{rightList}}" wx:key>
/*  注意图片标签里边添加 mode="widthFix"   */
/*你的卡片代码*/

</view>
</view>
</view>
</view>
</scroll-view>

wxss代码

.bottom{
  width: 100%;
  padding: 20rpx;
}
.bottom_z{
  display:flex;
  justify-content: space-around;
}
.left, .right{
  width: 345rpx;
  border-radius: 10rpx;
  box-shadow: 0 4px 8px 0 #f6f6f6,
   0 6px 20px 0 #f6f6f6;
   margin-top: 20rpx;
   margin-right: 20rpx;
   
}

js代码


let query
let rightHeight = 0 ,leftHeight = 0
let leftnum = -1,rightnum = -1,jia
Page({

 
 data: {
  zzlx:[
    /*填你的数组数据*/
  ],
  leftList:[],
  rightList:[]
 },

  

async isLeft() {
  const { zzlx, leftList, rightList } = this.data;
  query = wx.createSelectorQuery();
  
  for (const item of zzlx) {

    leftHeight <= rightHeight ? leftnum++ : rightnum++;
    leftHeight <= rightHeight ? jia=1 : jia=0;
   
   leftHeight <= rightHeight ? leftList.push(item) : rightList.push(item); 
 
   await this.getBoxHeight(leftList, rightList);
  
  }
 
 },

 async getBoxHeight(leftList, rightList) { //获取左右两边高度
  query = wx.createSelectorQuery();
  return new Promise((resolve, reject) => {
   this.setData({ leftList, rightList }, () => {
    if(jia == 1){
      query.select('#left').boundingClientRect()
      query.exec((res) => {
          leftHeight = res[0].height,
        resolve();
    });
    }else{
      query.select('#right').boundingClientRect();
      query.exec((res) => {
        rightHeight = res[0].height
        resolve();
    });
    }
   });
  })
 },


 onLoad: function (options) {
  this.isLeft()
}
})

这些代码是我花了一天的时间在网上找到的代码然后改了bug,,,,,好累,,

最后放下一个大佬的文章

微信小程序通过js实现瀑布流布局详解_javascript技巧_脚本之家 (jb51.net)

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦可尤曦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值