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

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

需求:页面有一列表,获取可视区域的数据;滑动过程中不处理,停止滑动后才获取。
实现原理:获取列表中每个条目的位置信息(元素顶部距可视区域顶部的距离),和可视区域比较,在可视范围内即认为可视元素
如下简单html结构
//列表


// 每个条目
{ { item.name }}

1
2
3
4
5
js方法
如果不需要判断是否滑动,则在onPageScroll中直接执行getVisibleItems方法即可
最终得到的visibleItems即为可视区域的数据,是一个数组,可通过每个元素的dataset获取绑定在元素上的字段,如上述html中的字段id
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
//可做后续逻辑处理
})
},
})

相关文章
|
27天前
|
小程序
微信小程序多种跳转页面方式
微信小程序多种跳转页面方式
|
4天前
|
小程序 JavaScript 开发工具
微信小程序——全局数据共享
微信小程序——全局数据共享
|
3天前
详细教程:扫码提交表单后,数据直接推送到企业微信、钉钉、飞书群聊
在草料制作的表单中,填表人扫码填写并提交数据后,这些信息可以立即通过企业微信、钉钉或飞书自动推送到相应的群聊中,实现即时共享和沟通,提升团队协作效率。
|
13天前
|
小程序 前端开发 生物认证
微信小程序如何将一个按钮放到页面的最底下?
微信小程序如何将一个按钮放到页面的最底下?
30 5
|
29天前
|
小程序 JavaScript 前端开发
微信小程序开发时数据是否是双向数据绑定的
微信小程序开发时数据是否是双向数据绑定的
|
1月前
|
小程序 开发者
万能的微信小程序个人主页:商城系统个人主页、外卖系统个人主页、购票系统个人主页等等【全部源代码分享+页面效果展示+直接复制粘贴编译即可】
这篇文章分享了四个不同应用场景下的微信小程序个人主页的源代码和页面效果展示,包括商城系统、外卖系统、医疗挂号和电影购票系统的个人主页。提供了完整的页面布局和样式代码,允许开发者直接复制粘贴并根据自己的项目需求进行简单的改造使用。
万能的微信小程序个人主页:商城系统个人主页、外卖系统个人主页、购票系统个人主页等等【全部源代码分享+页面效果展示+直接复制粘贴编译即可】
|
22天前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
45 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
22天前
|
小程序 前端开发 JavaScript
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
【避坑宝】是一款企业黑红名单吐槽小程序,旨在帮助打工人群体辨别企业优劣。该平台采用SpringBoot+MybatisPlus+uniapp+uview2等技术栈构建,具备丰富的注释与简洁的代码结构,非常适合实战练习与学习。通过小程序搜索“避坑宝”即可体验。
46 0
【项目实战】SpringBoot+uniapp+uview2打造一个企业黑红名单吐槽小程序
|
1月前
|
存储 小程序 JavaScript
|
1月前
|
小程序 前端开发 安全