src/uni_modules/uni-recycle-view/readme.md
此组件支持uni-app-x(web端、app端、小程序端),不支持非uni-app-x项目。此插件1.x版本最低支持HBuilderX 4.11,2.0及以上版本最低支持HBuilderX 4.81。
为了实现更流畅的滚动性能,自此插件2.0版本起,itemHeight为必传属性,既所有item高度一致才可以使用此组件。如果有动态item高度的需求可以下载1.x版本使用。
uni-recycle-view 组件是一个开源的、适用于展示超长列表的组件,它有2个优势:
uni-app x 的 list-view组件,在ui层面基于原生的recycle-view封装,对于长列表的渲染资源可以复用。
但在vue环境下,装载长列表会对列表所有数据都创建VNode,不管渲染层这些列表是否显示。创建大量VNode会影响初始化速度和内存占用。
uni-recycle-view 组件只创建了有限的VNode,循环复用这些VNode。uni-recycle-view组件内部通过计算决定哪些数据需要在界面展示,默认展示当前滚动位置的所在屏及上下各5屏的数据。
同时它也有一些限制和注意事项:
所以uni-recycle-view 组件是对list-view组件的一个补充方案。如果list-view的初始化速度和内存占用满足你的需求,那么继续使用list-view即可。
一般联网的分页加载列表,仍然可以使用list-view。uni-recycle-view 组件常见的场景是本地一次性遍历了大量数据并需要立即渲染在界面上。
在hello uni-app x的模板->自定义虚拟长列表示例中可以看到演示。
uni-recycle-view组件传入通过绑定list属性:list="list"传入含所有数据的列表。经过组件内部计算,由作用域插槽返回真实要渲染的部分数据v-slot:default="{items}"。最终仅需渲染items而不是list,从而节省了大量的计算消耗及内存占用。
| 属性名 | 类型 | 默认值 | 说明 |
|---|---|---|---|
| list | any[] | [] | 列表所有数据 |
| itemHeight | number | 40 | 每项占用高度(包括margin),此属性自2.0版本必传 |
| 其他 | - | - | 其余属性及事件会透传给内部的scroll-view组件,参考: scroll-view组件 |
uni-recycle-item用于渲染uni-recycle-view筛选出的用于展示的数据。
| 属性名 | 类型 | 默认值 | 说明 |
|---|---|---|---|
| offset | number | - | 由uni-recycle-view计算得来的组件偏移距离 |