您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在RecyclerView中,如果想要防止列表项点击事件穿透到下方的视图或布局,可以在列表项的点击事件中消费掉点击事件,使其不再向下传递。具体做法如下:
class MyAdapter(private val items: List<String>) : RecyclerView.Adapter<MyAdapter.ViewHolder>() {
class ViewHolder(view: View) : RecyclerView.ViewHolder(view) {
val textView: TextView = view.findViewById(R.id.textView)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val view = LayoutInflater.from(parent.context).inflate(R.layout.item_layout, parent, false)
return ViewHolder(view)
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.textView.text = items[position]
// 设置列表项的点击事件
holder.itemView.setOnClickListener {
// 处理点击事件
Toast.makeText(holder.itemView.context, "Item clicked: ${items[position]}", Toast.LENGTH_SHORT).show()
}
}
override fun getItemCount(): Int {
return items.size
}
}
holder.itemView.setOnClickListener {
Toast.makeText(holder.itemView.context, "Item clicked: ${items[position]}", Toast.LENGTH_SHORT).show()
// 消费掉点击事件,不再向下传递
true
}
通过在点击事件中返回true来消费掉点击事件,从而防止事件继续向下传递。这样就可以避免RecyclerView列表项点击事件穿透到下方的视图或布局。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。