本文是介绍 RecyclerView 入门 系列文章 的第三篇。如果您曾经对创立 RecyclerView 有了肯定的意识,请持续浏览本文。如果尚未相熟,建议您首先浏览本系列中的 第一篇文章。
当应用 RecyclerView
显示列表数据的时候,您可能须要响应列表元素的点击事件。该响应解决包含: 关上蕴含更多数据的页面、显示 toast、删除某个元素等等。相干的响应事件尽管不可胜数,然而它们均须要通过 onClick()
来实现。
定义点击动作
在创立监听器之前,在 Activity 类中增加一个函数用于解决点击之后的响应操作。
<!-- Copyright 2019 Google LLC.
SPDX-License-Identifier: Apache-2.0 -->
private fun adapterOnClick(flower: Flower) {val intent = Intent(this, FlowerDetailActivity()::class.java)
intent.putExtra(FLOWER_ID, flower.id)
this.startActivity(intent)
}
接下来,批改 Adapter 的构造函数来传入 onClick() 函数。
<!-- Copyright 2019 Google LLC.
SPDX-License-Identifier: Apache-2.0 -->
class FlowersAdapter(private val onClick: (Flower) -> Unit) :
ListAdapter<Flower, RecyclerView.ViewHolder>(FlowerDiffCallback())
在 Activity 类中,在初始化 Adapter 的时候传入刚刚创立的点击事件函数。
<!-- Copyright 2019 Google LLC.
SPDX-License-Identifier: Apache-2.0 -->
val flowersAdapter = FlowersAdapter { flower ->
adapterOnClick(flower)
}
增加 onClickHandler()
当初响应解决曾经定义好了,能够将它关联到 Adapter 的 ViewHolder 了。
批改 ViewHolder,将 onClick() 作为参数传入。
<!-- Copyright 2019 Google LLC.
SPDX-License-Identifier: Apache-2.0 -->
class FlowerViewHolder(itemView: View, val onClick: (Flower) -> Unit) :
RecyclerView.ViewHolder(itemView)
在初始化的代码中,调用 itemView 的 setOnClickListener{}。
<!-- Copyright 2019 Google LLC.
SPDX-License-Identifier: Apache-2.0 -->
init {
itemView.setOnClickListener {
currentFlower?.let {onClick(it)
}
}
}
搞定!当初您的 RecyclerView
能够响应点击事件了。
编程高兴!
下一步
请查阅蕴含 onClick() 的 残缺示例。
感谢您浏览 RecyclerView 系列 文章的第三篇。请持续关注将来更多对于 RecyclerView
的内容。
如果您想理解更多对于 onClick() 的内容,请参考 官网文档。