正确实现 RecyclerView 适配器的点击监听器
Implementing click listener for RecyclerView adapter correctly
为 RecyclerView
适配器中的项目创建点击侦听器的正确方法是什么? This tutorial 说应该在 onBindViewHolder
中完成,但其他人在 onCreateViewHolder
中说过,我没有看到后者的任何教程,因此我很困惑。
class MyRVAdapter(private val myList: ArrayList<Item>) : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun getItemCount(): Int {
return myList.size
}
class ViewHolder (itemView : View):RecyclerView.ViewHolder(itemView) {
// val myButton = itemView.findViewById<Button>(R.id.btn_A)!!
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.myButton.text = (myList[position].btnTitle)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.my_cv, parent, false)
return ViewHolder(v)
val myButton = v.findViewById<Button>(R.id.btn_A)!!
myButton.setOnClickListener {
customView = View.inflate(holder.itemView.context, R.layout.fragment_dialog, null)
val builder = AlertDialog.Builder(holder.itemView.context)
builder.setIconAttribute(R.attr.imgInfo)
builder.setTitle(R.string.dialog_title)
builder.setView(customView)
builder.setPositiveButton(android.R.string.ok){ dialog, _ -> dialog.dismiss() }
builder.show()
}
}
}
在 Kotlin 中
在 Kotlin 中,您不能直接在 ViewHolderClass 中实现 onClickListener。
在 Kotlin 中要实现相同的目的,您必须在 onBindViewHolder
中执行 onClickListener
holder.myButton.setOnClickListener {
//do your stuff here
}
或使用初始化函数
// I'm not sure this is a correct method or not
class MyRVAdapter : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun getItemCount(): Int {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyRVAdapter.ViewHolder {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
class ViewHolder(itemView: View): RecyclerView.ViewHolder(itemView) {
var myButton = itemView.findViewById(R.id.button) as Button
// use any of the following declaratons
// val myButton = itemView.findViewById(R.id.button) as Button
// val myButton = itemView.findViewById<Button>(R.id.button)
// var myButton = itemView.findViewById<Button>(R.id.button)
// var myButton:Button = itemView.findViewById(R.id.button)
// val myButton:Button = itemView.findViewById(R.id.button)
// to avoid Expecting Member Declaration is showing in kotlin use constructor
// Expecting Member Declaration is showing because kotlin allows null declaration so a constructor or init is required to avoid this
init {
myButton.setOnClickListener{
//do your stuff here
}
}
}
}
在Java
onBindViewHolder
只要数据有变化就会执行。所以把ViewHolderClass
写成onClickListener
就好了。
myButton.setOnClickListener {
//do your stuff here
}
当您的视图出现在屏幕上时,onBindViewHolder()
将一直被调用,因此它被调用的次数多于您的项目数。当你滚动时,你会创建很多重复的监听器。在 ViewHolder 中设置监听器将为每个持有者创建一个监听器。这是代码:
class MyRVAdapter() : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.myButton.text = "set here all except listener"
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.my_cv, parent, false)
return ViewHolder(v)
}
override fun getItemCount(): Int {
return myList.size
}
class ViewHolder (itemView: View) : RecyclerView.ViewHolder(itemView) {
var myButton: Button = itemView.findViewById(R.id.btn_A)
init {
myButton.setOnClickListener {
val customView = View.inflate(itemView.context, R.layout.fragment_dialog, null)
val builder = AlertDialog.Builder(itemView.context)
builder.setIconAttribute(R.attr.imgNight)
builder.setTitle(R.string.dialog_title)
builder.setView(customView)
builder.setPositiveButton(android.R.string.ok){ dialog, _ -> dialog.dismiss() }
builder.show()
val tabLayout = customView.findViewById(R.id.mTabLayout)
val viewPager = customView.findViewById(R.id.mViewPager)
val adapter = TabbedDialogAdapter(childFragmentManager)//i dont understand how you get this but it is another question
adapter.addFragment("Tab A", TabbedDialogFragment.createInstance("Description A"))
adapter.addFragment("Tab B", TabbedDialogFragment.createInstance("Description B"))
adapter.addFragment("Tab C", TabbedDialogFragment.createInstance("Description C"))
viewPager.adapter = adapter
tabLayout.setupWithViewPager(viewPager)
}
}
}
}
为 RecyclerView
适配器中的项目创建点击侦听器的正确方法是什么? This tutorial 说应该在 onBindViewHolder
中完成,但其他人在 onCreateViewHolder
中说过,我没有看到后者的任何教程,因此我很困惑。
class MyRVAdapter(private val myList: ArrayList<Item>) : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun getItemCount(): Int {
return myList.size
}
class ViewHolder (itemView : View):RecyclerView.ViewHolder(itemView) {
// val myButton = itemView.findViewById<Button>(R.id.btn_A)!!
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.myButton.text = (myList[position].btnTitle)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.my_cv, parent, false)
return ViewHolder(v)
val myButton = v.findViewById<Button>(R.id.btn_A)!!
myButton.setOnClickListener {
customView = View.inflate(holder.itemView.context, R.layout.fragment_dialog, null)
val builder = AlertDialog.Builder(holder.itemView.context)
builder.setIconAttribute(R.attr.imgInfo)
builder.setTitle(R.string.dialog_title)
builder.setView(customView)
builder.setPositiveButton(android.R.string.ok){ dialog, _ -> dialog.dismiss() }
builder.show()
}
}
}
在 Kotlin 中
在 Kotlin 中,您不能直接在 ViewHolderClass 中实现 onClickListener。
在 Kotlin 中要实现相同的目的,您必须在 onBindViewHolder
holder.myButton.setOnClickListener {
//do your stuff here
}
或使用初始化函数
// I'm not sure this is a correct method or not
class MyRVAdapter : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun getItemCount(): Int {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyRVAdapter.ViewHolder {
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
}
class ViewHolder(itemView: View): RecyclerView.ViewHolder(itemView) {
var myButton = itemView.findViewById(R.id.button) as Button
// use any of the following declaratons
// val myButton = itemView.findViewById(R.id.button) as Button
// val myButton = itemView.findViewById<Button>(R.id.button)
// var myButton = itemView.findViewById<Button>(R.id.button)
// var myButton:Button = itemView.findViewById(R.id.button)
// val myButton:Button = itemView.findViewById(R.id.button)
// to avoid Expecting Member Declaration is showing in kotlin use constructor
// Expecting Member Declaration is showing because kotlin allows null declaration so a constructor or init is required to avoid this
init {
myButton.setOnClickListener{
//do your stuff here
}
}
}
}
在Java
onBindViewHolder
只要数据有变化就会执行。所以把ViewHolderClass
写成onClickListener
就好了。
myButton.setOnClickListener {
//do your stuff here
}
onBindViewHolder()
将一直被调用,因此它被调用的次数多于您的项目数。当你滚动时,你会创建很多重复的监听器。在 ViewHolder 中设置监听器将为每个持有者创建一个监听器。这是代码:
class MyRVAdapter() : RecyclerView.Adapter<MyRVAdapter.ViewHolder>() {
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.myButton.text = "set here all except listener"
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.my_cv, parent, false)
return ViewHolder(v)
}
override fun getItemCount(): Int {
return myList.size
}
class ViewHolder (itemView: View) : RecyclerView.ViewHolder(itemView) {
var myButton: Button = itemView.findViewById(R.id.btn_A)
init {
myButton.setOnClickListener {
val customView = View.inflate(itemView.context, R.layout.fragment_dialog, null)
val builder = AlertDialog.Builder(itemView.context)
builder.setIconAttribute(R.attr.imgNight)
builder.setTitle(R.string.dialog_title)
builder.setView(customView)
builder.setPositiveButton(android.R.string.ok){ dialog, _ -> dialog.dismiss() }
builder.show()
val tabLayout = customView.findViewById(R.id.mTabLayout)
val viewPager = customView.findViewById(R.id.mViewPager)
val adapter = TabbedDialogAdapter(childFragmentManager)//i dont understand how you get this but it is another question
adapter.addFragment("Tab A", TabbedDialogFragment.createInstance("Description A"))
adapter.addFragment("Tab B", TabbedDialogFragment.createInstance("Description B"))
adapter.addFragment("Tab C", TabbedDialogFragment.createInstance("Description C"))
viewPager.adapter = adapter
tabLayout.setupWithViewPager(viewPager)
}
}
}
}