data:image/s3,"s3://crabby-images/43c96/43c96015b78ebacfb14c3b57409aade6b210e63c" alt="Inflating listview android studio"
If we look at our adapter code now, you would see that it’s starting to do too much.
data:image/s3,"s3://crabby-images/f65de/f65de2eb8666f854d50828be2aec991e1c6daa9f" alt="inflating listview android studio inflating listview android studio"
inner class MyViewHolder( itemView: View, private val onTextViewTextClicked: (position: Int) -> Unit ) : RecyclerView.ViewHolder(itemView) For the logic to pull the data out from the position, we will offload it onto the adapter. Instead of returning the whole data class back onto the callback, we will return only the position of ViewHolder. Currently, we're setting a new listener every single time, What if we could transfer it inside ViewHolder initialization or onto onCreateView, then it will only be executed one time and will be recycled for later use.
data:image/s3,"s3://crabby-images/53d36/53d3681e0f98836e29f3ecfdeca432f94e8ee9e3" alt="inflating listview android studio inflating listview android studio"
data:image/s3,"s3://crabby-images/4e8af/4e8afff4544c058a236b282ffc171c09245b228e" alt="inflating listview android studio inflating listview android studio"
Notice anything that we could recycle here as well? The answer is the OnClickListener that is being used.
data:image/s3,"s3://crabby-images/43c96/43c96015b78ebacfb14c3b57409aade6b210e63c" alt="Inflating listview android studio"