微信小程序开发 懒加载+瀑布流+排序功能

在小程序的开发过程中,遇到了这样的功能需求:在保持瀑布流布局的情况下,使用懒加载来渲染页面,并且要求对其中的属性添加排序功能。

单独拿出来都是很好实现的功能,但是当三个功能联系在一起时,问题就出现了。

最开始采用了CSS的方式来实现瀑布流,即通过属性column-count来控制列数,但很快发现,这样的瀑布流的顺序是从上到下后再从左到右,与原型图的要求并不符合,况且在加上懒加载后,由于整体的数据数量发生了变化,整个瀑布流相当于又重新加载了一次,不仅不能实现功能,还加大了加载的压力

所幸瀑布流还可以通过JS来进行实现,在查阅了相关的方法后,找到了符合要求的写法,具体如下:

采用左右两列布局,实时判断两侧的高度,当一侧大于另一侧时,就将对应的内容添加到少的一侧

js代码:

复制代码
async isLeft(list, leftList, rightList) {
    let t = this;
    query = wx.createSelectorQuery();
    for (const item of list) {
      leftHeight <= rightHeight ? leftList.push(item) : rightList.push(item); //判断两边高度,来决定添加到那边
      await this.getBoxHeight(leftList, rightList);
    }
    console.log(leftList, rightList);
    setTimeout(() => {
      t.setData({
        show: "visible"
      })
    }, 1000)

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

wxml:

复制代码
<view id="left">
      <view class="store_item" wx:for="{{leftList}}" wx:key="indexs" bindtap="storeIndex" data-id="{{item.id}}">
        <view class="store_img">
          <image mode="widthFix" lazy-load="true" src="" />
        </view>
        <view class="store_text">
          <view class="text">测试用</view>
          <view class="view">
            <text>浏览量:{{item.show_view}}</text>
          </view>
        </view>
      </view>
    </view>
    <view id="right">
      <view class="store_item" wx:for="{{rightList}}" wx:key="indexs" bindtap="storeIndex" data-id="{{item.id}}">
        <view class="store_img">
          <image mode="widthFix" lazy-load="true" src="" />
        </view>
        <view class="store_text">
          <view class="text">测试用</view>
          <view class="view">
            <text>浏览量:{{item.show_view}}</text>
          </view>
        </view>
      </view>
    </view>
    <view style="clear: both;"></view>

注意需要为左右两个列表设置浮动

复制代码
#left{
  width: 49%;
  float: left;
}
#right{
  width: 49%;
  float: left;
  margin-left: 2%;
}

这样我们的瀑布流布局就算实现了

懒加载:

复制代码
onReachBottom: function () {
    let t = this
    const start = this.data.renderedGoodsList.length; // 计算当前已渲染数据的末尾索引
    const end = Math.min(start + this.data.pageSize, this.data.list.length); // 计算下一批数据的结束索引
    const nextBatch = this.data.list.slice(start, end); // 获取下一批数据
    const newRenderedGoodsList = this.data.renderedGoodsList.concat(nextBatch); // 合并新数据
    this.isLeft(nextBatch, t.data.leftList, t.data.rightList);
    this.setData({
      renderedGoodsList: newRenderedGoodsList
    });
  },

绑定在页面最外层的scroll-view滚动事件上即可,每当滚动到底部时都会触发

<scroll-view scroll-y style="height: 100vh" bindscrolltolower="onReachBottom">

最后需要注意的是,在触发切换事件导致排序发生变化时,应当手动将左右两侧的列表的高度清空,防止重新识别高度时产生的错判导致左右换位。

希望能为你带来帮助

相关推荐
是大刚啊10 小时前
微信小程序原生车牌输入器
微信小程序·小程序·tdesign·车牌号·车牌输入
韩立学长13 小时前
【开题答辩实录分享】以《宠物领养微信小程序》为例进行答辩实录分享
微信小程序·宠物
玖月晴空15 小时前
Uniapp 速查文档
前端·微信小程序·uni-app
2501_9159184116 小时前
App 上架苹果商店全流程详解 从开发者账号申请到开心上架(Appuploader)跨平台免 Mac 上传实战指南
macos·ios·小程序·uni-app·objective-c·cocoa·iphone
说私域16 小时前
定制开发开源AI智能名片S2B2C商城小程序中的羊群效应应用研究
人工智能·小程序
一匹电信狗17 小时前
【C++】红黑树详解(2w字详解)
服务器·c++·算法·leetcode·小程序·stl·visual studio
CsharpDev-奶豆哥17 小时前
微信小程序通过主键ID修改json数据的技术分享
微信小程序·小程序·json
汤姆yu17 小时前
基于微信小程序的防诈骗管理系统
微信小程序·小程序·防诈骗管理
2501_9160074717 小时前
从零开始学习iOS App开发:Xcode、Swift和发布到App Store完整教程
android·学习·ios·小程序·uni-app·iphone·xcode
2501_9160088919 小时前
前端工具全景实战指南,从开发到调试的效率闭环
android·前端·小程序·https·uni-app·iphone·webview