公司最近要做一个类似于探探滑动卡片的需求,经过周五和周末两天的啪啦啪啦,终于做出来基本符合需求的组件,最终的效果图就是这样的了。
此组件是使用原生微信小程序代码开发的一款高性能的卡片滑动组件,无外部依赖,导入即可使用。其主要功能效果类似探探的卡片滑动。
git clone https://github.com/hspprogrammer/wx_card_swiper.git
/components
/pages
其中,components文件夹下的card组件是cardSwipe组件的抽象节点,放置卡片内容,需要调用者自己实现。而cardSwipe组件为卡片功能的具体实现。pages下的index为调用组件的页面,可供参考。
场景1:实现一个超多的卡片展示(比如1000张)
原本实现思路:利用wx:if,只渲染当前展示的card和后面两张card,然后监听cardChange回调函数,再切换到比如最后三张的时候请求下一页数据,直接push到渲染的数组中,因为有wx:if的控制,虽然数据增多,但渲染的节点还是只有三个。具体的性能没有测试,但在手机测试时候,直观感觉没有多大的性能问题。
新的实现思路:首先要实现循环展示的逻辑,以分页的形式每次从后台获取数据,先获取第一页cardsData和第二页nextPageData的数据。每切换一张图片就从nextPageData拿到相同位置的数据替换cardsData的数据,当切换到第一页的最后showNum(一次性展示几个card)条数据时候,会进入到循环从头重新开始渲染cardsData的数据,这个时候cardsData里的数据实际是下一页nextPageData的数据,同时再请求第三页的数据赋值给nextPageData,循环往复。。。。。。
感谢思路来源提供思路,代码逻辑自己实现。