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

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

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

如下简单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
	      //可做后续逻辑处理
	    })
	},
})
相关推荐
郭wes代码1 小时前
Cmd命令大全(万字详细版)
python·算法·小程序
.生产的驴6 小时前
SpringBoot 对接第三方登录 手机号登录 手机号验证 微信小程序登录 结合Redis SaToken
java·spring boot·redis·后端·缓存·微信小程序·maven
汤姆yu12 小时前
基于微信小程序的乡村旅游系统
微信小程序·旅游·乡村旅游
计算机徐师兄12 小时前
基于TP5框架的家具购物小程序的设计与实现【附源码、文档】
小程序·php·家具购物小程序·家具购物微信小程序·家具购物
曲辒净12 小时前
微信小程序实现二维码海报保存分享功能
微信小程序·小程序
朽木成才14 小时前
小程序快速实现大模型聊天机器人
小程序·机器人
peachSoda714 小时前
随手记:小程序使用uni.createVideoContext视频无法触发播放
小程序
何极光14 小时前
uniapp小程序样式穿透
前端·小程序·uni-app
小墨&晓末15 小时前
【PythonGui实战】自动摇号小程序
python·算法·小程序·系统安全
oil欧哟1 天前
🤔认真投入一个月做的小程序,能做成什么样子?有人用吗?
前端·vue.js·微信小程序