小程序 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('没有更多数据了!');
	            }
	}
......
相关推荐
2501_9339072116 小时前
宁波小程序开发服务与技术团队专业支持
科技·微信小程序·小程序
sheji34161 天前
【开题答辩全过程】以 基于微信小程序的少儿编程学习平台为例,包含答辩的问题和答案
学习·微信小程序·小程序
const_qiu1 天前
微信小程序自动化测试100%通过率实践
微信小程序·小程序
Greg_Zhong1 天前
小程序中登出/切换/重置页面状态的使用
小程序
一字白首1 天前
微信小程序进阶实战:从 UI 组件库到全局状态管理全解DAY05
ui·微信小程序·小程序
海石2 天前
微信小程序开发02:原始人也能看懂的着色器与视频处理
前端·微信小程序·视频编码
li9056632802 天前
hanzi-writer-miniprogram Path2D问题以及Bug修复
微信小程序·bug
土土哥V_araolin2 天前
双迪大健康新零售系统开发要点
小程序·个人开发·零售
2501_915909062 天前
不用越狱就看不到 iOS App 内部文件?使用 Keymob 查看和导出应用数据目录
android·ios·小程序·https·uni-app·iphone·webview
CHU7290352 天前
扭蛋机盲盒小程序前端功能设计及核心玩法介绍
前端·小程序