如何在Adapter中优雅的使用Context

如何在Adapter中优雅的使用Context

 

1. 前言

最近我在项目中,发现一个同事写 RecyclerView.Adapter 的时候都习惯定义一个全局的私有 mContext,然后在 onCreateViewHolder(parent: ViewGroup, viewType: Int) 方法中进行赋值操作 mContext = parent.context。

如下:

class MyAdapter(private val dataList: List<MyData>) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() {
    private lateinit var mContext: Context

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
    	//在这里进行context的赋值
        mContext = parent.context
        val view = LayoutInflater.from(parent.context).inflate(R.layout.rcy_item_view, parent, false)
        return MyViewHolder(view)
    }

    override fun getItemCount(): Int {}

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {}
}

如何在Adapter中优雅的使用Context

 

WT,还可以这么操作!!第一次见到这样的写法,有点意思,由此有了这一篇文章。

2. 获取到 Context 的四种方式

很多时候我们需要在 RecyclerView.Adapter 中使用到 context,比如:利用 Glide 来加载网络图片的时候。

如何在Adapter中优雅的使用Context

 

这时,我们该如何拿到 context 给 Glide 呢?

2.1 通过 Adapter 构造函数传入 Context

这是我之前最常用的一种方式,通过 Adapter 构造函数将当前Activity Context传进来,如下:

class MyAdapter(
    private val context: Context,
    private val dataList: List<MyData>
) : RecyclerView.Adapter<MyAdapter.MyViewHolder>() {

    class MyViewHolder(val binding: RcyItemViewBinding) :
        RecyclerView.ViewHolder(binding.root) {
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
        val binding = RcyItemViewBinding.inflate(
            LayoutInflater.from(parent.context),
            parent,
            false
        )
        return MyViewHolder(binding)
    }

    override fun getItemCount(): Int = dataList.size

    override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
        val data = dataList[position]
        holder.binding.apply {
            Glide.with(context).load(data.imageUrl).into(holder.binding.imageIv)
            holder.binding.contentTv.text = data.content
        }
    }
}

2.2 通过 Parent.conte

  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android ,我们可以在 Adapter 使用 OnClickListener 来实现点击事件。以下是实现步骤: 1. 在 Adapter 定义一个内部类 ViewHolder,ViewHolder 包含需要显示的 View 对象以及需要处理点击事件的 View 对象。 2. 在 onCreateViewHolder 方法创建 ViewHolder 对象,并将需要处理点击事件的 View 对象的 OnClickListener 设置为 ViewHolder 内部类定义的 OnClickListener。 3. 在 onBindViewHolder 方法将数据绑定到 ViewHolder 需要显示的 View 对象。 4. 在内部类 ViewHolder 实现 OnClickListener 接口,并在 onClick 方法处理点击事件。 以下是示例代码: ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mData; public MyAdapter(List<String> data) { mData = data; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); ViewHolder viewHolder = new ViewHolder(view); viewHolder.mTextView.setOnClickListener(viewHolder); return viewHolder; } @Override public void onBindViewHolder(ViewHolder holder, int position) { holder.mTextView.setText(mData.get(position)); } @Override public int getItemCount() { return mData.size(); } public static class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener { public TextView mTextView; public ViewHolder(View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } @Override public void onClick(View view) { int position = getAdapterPosition(); // 处理点击事件 } } } ``` 在 ViewHolder 内部类实现 OnClickListener 接口,并在 onClick 方法处理点击事件。在 onCreateViewHolder 方法创建 ViewHolder 对象,并将需要处理点击事件的 View 对象的 OnClickListener 设置为 ViewHolder 内部类定义的 OnClickListener。在 onBindViewHolder 方法将数据绑定到 ViewHolder 需要显示的 View 对象

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值