微信小程序—页面滑动,获取可视区域数据

需求:页面有一列表,获取可视区域的数据;滑动过程中不处理,停止滑动后才获取。

实现原理:获取列表中每个条目的位置信息(元素顶部距可视区域顶部的距离),和可视区域比较,在可视范围内即认为可视元素

如下简单html结构
javascript 复制代码
//列表
<view class="list">
	// 每个条目
	<view class="item" wx:for={{ data }} data-id={{ item.id }}>{{ item.name }}</view>
</view>
js方法
  • 如果不需要判断是否滑动,则在onPageScroll中直接执行getVisibleItems方法即可
最终得到的visibleItems即为可视区域的数据,是一个数组,可通过每个元素的dataset获取绑定在元素上的字段,如上述html中的字段id
javascript 复制代码
Page({
	//....其他逻辑
	let scrollTimer = null  //定义一个全局的滑动定时器 用来判断是否正在滑动,如果不需要判断是否滑动,则在onPageScroll中直接执行getVisibleItems方法即可
	//页面滑动监听方法
	onPageScroll: function (e) {
		//一直滑动 一直清楚 直到滑动停止1s后,执行获取方法
		if(scrollTimer){
	      clearTimeout(scrollTimer)
	    }
	    // 赋值延迟方法 停止滑动后执行
	    scrollTimer = setTimeout(() => {
	      this.getVisibleItems()
	    }, 1000);
	},
	getVisibleItems(){
		//创建一个选择器
		const query = wx.createSelectorQuery().in(this);
		//获取列表内所有条目元素 在界面的位置信息
	    query.selectAll('.item').boundingClientRect();
	    query.selectViewport().scrollOffset();
	    query.exec((res) => {
	      //所有选中的条目数据
	      const listItemRects = res[0];
	      //获取设备的视口高度 (如果有底导航其他固定底部的元素可在此减去其高度)
	      const viewportHeight = wx.getSystemInfoSync().windowHeight;
	      // 获取可见的列表项
	      const visibleItems = listItemRects.filter(rect => {
	      	//元素局顶部的距离 (如果顶部有固定的tab或导航栏可在此减去其高度)
	        console.log(rect.top) 
	        console.log(viewportHeight)
	        // 元素距离顶部的距离在此范围内 即认为在可视范围内
	        return rect.top && rect.top < viewportHeight;
	      })
	      //visibleItems即为可视区域的数据,是一个数组,可通过dataset获取绑定在元素上的字段,如上述html中的字段id
	      //可做后续逻辑处理
	    })
	},
})
相关推荐
恩创软件开发21 小时前
创业日常2026-1-8
java·经验分享·微信小程序·小程序
腾讯云云开发1 天前
微信发布AI小程序成长计划:免费云开发资源+1亿token额度!
微信小程序·ai编程·小程序·云开发
开发加微信:hedian1161 天前
推客与分销场景下的系统架构实践:如何支撑高并发与复杂业务规则
小程序
游九尘1 天前
在小程序中实现横竖屏切换的配置方法,实时监听页面宽度
小程序
weixin_lynhgworld1 天前
[特殊字符]旧物焕新颜,二手变宝藏——小程序系统开发开启绿色生活新篇章[特殊字符]
小程序·生活
说私域1 天前
小程序电商运营中“开源AI智能名片链动2+1模式S2B2C商城小程序”对培养“老铁”用户的重要性研究
人工智能·小程序·开源
00后程序员张1 天前
在 iPhone 上进行 iOS 网络抓包的实践经验
android·ios·小程序·https·uni-app·iphone·webview
weixin_lynhgworld1 天前
[特殊字符]短剧小程序:解锁碎片时间,畅享无限娱乐[特殊字符]
小程序·娱乐
2501_915918411 天前
介绍如何在电脑上查看 iPhone 和 iPad 的完整设备信息
android·ios·小程序·uni-app·电脑·iphone·ipad
2501_916008891 天前
没有 Mac 如何在 Windows 上创建 iOS 应用描述文件
android·macos·ios·小程序·uni-app·iphone·webview