小程序 scroll-view 触底事件不触发问题

问题描述

前端本来触底增加页数,每页写死的10条数据,本来模拟器测试还好好的触发 scrolltolower 触底事件,但是用手机预览,看到10条数据显示的都没到底部,然后触底事件也不触发。

问题原因

scroll-view组件之上拉加载下拉刷新
微信小程序获取某个元素的高度宽度
微信小程序px和rpx之间的转换

主要原因:第一次获取的数据 item 的 总高度比 scroll-view 的实际高度小,所以不触发 => 则需要计算当前高度能显示多少个 item, 即 pageSize 的大小。

问题解决

那就计算下 pageSize,

  1. 需要设定 scroll-view 的高度或者默认。本次是使用的 uview u-list 组件,绑定 height 单位为 rpx ,所以要设置的话计算得到之后要转成 rpx 的大小。
  2. 默认获取到 最小的 Item 的高度,进行除于计算。

大体代码如下:

复制代码
					......
					:height="height"
                    @scrolltolower="scrolltolower"
                    ......

onLoad() {
     // pagesize = (list 总高度 + 5px) / item 的最小高度
     let query = wx.createSelectorQuery();
     let width = uni.getSystemInfoSync().windowWidth;
     let itemHeight = 150; // rpx
     let px = (150 / 750) * width + 1; // 转成 px
     let _me = this;
     query
         .select('.my-list')
         .boundingClientRect(function(rect) {
             let num = Math.ceil(height / px);
             _me.pageSize = num;
             _me.currentPage = 1;
             _me.totalPage = 1;
             _me.getList();
         })
         .exec();
 },

......
	scrolltolower() {
		console.log('loadmore');
	            if (this.currentPage < this.totalPage) {
	                this.currentPage++;
	                this.getList('loadmore');
	            } else {
	                console.log('没有更多数据了!');
	            }
	}
......
相关推荐
斯班奇的好朋友阿法法3 小时前
鸿蒙 vs iOS vs 微信小程序:开发平台全面对比
ios·微信小程序·harmonyos
cosinmz1 天前
图片太多太乱怎么整理?分享一个我最近常用的图片转 PDF方法
经验分享·小程序·pdf
科技互联.1 天前
2026年小程序定制市场:个性化需求激增,技术深度成竞争关键
人工智能·小程序
小羊Yveesss2 天前
2026年小程序商城的现状和发展趋势
小程序
Greg_Zhong2 天前
微信小程序如何关闭:当前渲染模式为webview?
微信小程序·微信小程序渲染引擎·渲染引擎需搭配更高基础库
橘子海全栈攻城狮2 天前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
智慧景区与市集主理人2 天前
五一市集分账混乱?巨有科技智慧市集小程序实现统一收款、自动分账
大数据·科技·小程序
程序鉴定师2 天前
深圳小程序制作哪家好?2026深度市场分析与选择指南?
大数据·小程序
河北清兮网络科技2 天前
广告联盟全解析:从开发接入到运营优化,多视角拆解流量变现逻辑
小程序·app
计算机学姐2 天前
基于微信小程序的校园失物招领管理系统【uniapp+springboot+vue】
java·vue.js·spring boot·mysql·信息可视化·微信小程序·uni-app