在最开始入门介绍中,我们曾经用 SingleComponentSection
完成了一个简单的列表,当时的做法是使用 for 构造出了多个子 Component。其实在 Litho 中提供了一个性能更好的方式,专门处理这种数据(这种数据其实就是类似于 Android 中的 adapter 与其绑定的数据)。 Litho 中专门处理这种模板与列表支持的组件叫做
DataDiffSection
的使用DataDiffSection
。下面用 DataDiffSection
我们重构一下之前写的MainListViewSpec
。
val data = arrayListOf<Int>()
for (i in 0 until 32) {
data.add(i)
}
MainListViewSpec
中增加一个创建ListItemView
组件的方法: @OnEvent(RenderEvent::class)
fun onRender(c: SectionContext, @FromEvent model: Int): RenderInfo {
return ComponentRenderInfo.create().component(
ListItemView.create(c)
.color(if (model % 2 == 0) Color.WHITE else Color.LTGRAY)
.title(if (model % 2 == 0) "hello word" else model.toString())
.build()
).build()
}
onCreateChildren
方法: @OnCreateChildren
fun createChildren(c: SectionContext, @Prop listData: ArrayList<Int>):Children {
return Children.create()
.child(
DataDiffSection.create<Int>(c)
.data(listData)
.renderEventHandler(MainListView.onRender(c))
)
.build()
}
···
val recycleView = RecyclerCollectionComponent.create(c).disablePTR(false)
.section(MainListView.create(SectionContext(this)).listData(data)).build()
setContentView(LithoView.create(c, recycleView))
···
可能大部分到这里都有点蒙,DataDiffSection
到底是从哪里来的呢? DataDiffSection
有点类似于 Android 的 DiffUtil
它是一个内置的一个事件:
renderEventHandler
,就是上面代码中的MainListView.onRender(c)
。 可以看到效果跟之前的没有区别: 在最开始我们是使用 SingleComponentSection
构建列表的。这里如果需要嵌套一个横向滚动的列表,同样也可以用 SingleComponentSection
来完成:
val config = ListRecyclerConfiguration.create()
.orientation(LinearLayoutManager.HORIZONTAL)
.reverseLayout(false)
.snapMode(SnapUtil.SNAP_TO_CENTER)
.build()
RecyclerCollectionComponent.create(c)
.disablePTR(true)
.recyclerConfiguration(config)
.section(DataDiffSection.create<Int>(c)
.data(listData)
.renderEventHandler(SectionItem.onRender(c)))
.canMeasureRecycler(true)
![Video_20200909_112127_733.gif][2] [2]: https://raw.githubusercontent.com/appdev/gallery/main/img/3c3c3037b9b54ce4a9f772778fcf29f1%7Etplv-k3u1fbpfcp-zoom-in-crop-mark_1512_0_0_0.webp