在Tarojs的VirtualList组件中支持下拉刷新功能

前情提要

最近在使用Tarojs做开发,主要用于微信小程序和h5,遇到了很多兼容性问题。比如本文要说的虚拟列表组件。项目中使用的tarojs版本是3.6.14,官网文档中说虚拟列表有onScrollToUpper事件,实际使用却没有,查看源码后也没有看到相关代码,不知道是哪里有问题,有知道的小伙伴可以说下~

先看效果

实现方案

其实实现下拉刷新功能本身是比较容易的,基本上就是在touchstart,touchmove,touchend上做处理,关键还是在兼容性和其他各种异常的处理上。

判定下拉刷新操作

通常情况下,只需要判断滚动条位置为0的时候,就可以认为已经在顶部了,对于touch就可以进入下拉刷新的代码了。但是virtualList中却不能根据这个来判断,在virtualList中通过监听scroll事件获取到的滚动条偏移量scrollOffset,他只是个参考值,甚至可能是负的。

解决方案,通过dom查找的方式获取到列表的第一个元素,因为virtualList默认是用绝对定位来实现的,所以只需要找到style.top的值是0的就是第一个元素。通过在初始化的时候记录下该元素的位置信息(使用boundingClientRect函数获取),将其top值记录下来。当页面上存在第一个元素,并且他的当前位置和初始位置相同,就可以认为他是回到了初始位置,也就是回到了顶部。

特殊的,在微信小程序端通过Taro.createSelectorQuery()的方式查找到节点,此操作是异步的。如果是在快速滚动操作时,可能最终查找的节点位置信息是滚动操作后的(不准确的),所以又必须保证异步计算的结果是当时的快照,所以用了订阅-发布的形式。如果判断touchstart时的位置是顶部的,就追加一个下拉的动画效果(动画就是在touchmove中将移动的偏移量赋值到刷新面板的高度上)。

相关推荐
子兮曰5 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen6 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧05137 小时前
ctf show web 入门42
android·前端·android studio
kyriewen7 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u7 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby7 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情6738 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇8 小时前
前端转后端:SQL 是什么
前端
张元清9 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技9 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端