首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

RecyclerView -如何将onBindViewHolder的位置传递给ViewHolder类?

在RecyclerView中,我们可以通过使用构造函数或setter方法将onBindViewHolder的位置传递给ViewHolder类。

方法1:通过构造函数传递位置 我们可以在ViewHolder类的构造函数中添加一个额外的参数来接收位置信息。例如:

代码语言:txt
复制
public class MyViewHolder extends RecyclerView.ViewHolder {
    public MyViewHolder(View itemView, int position) {
        super(itemView);
        // 在这里可以使用传递进来的位置信息进行处理
    }
}

然后,在onCreateViewHolder方法中,我们创建ViewHolder对象时,将位置信息传递给它:

代码语言:txt
复制
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
    return new MyViewHolder(itemView, position);
}

方法2:通过setter方法传递位置 我们也可以在ViewHolder类中添加一个setter方法来接收位置信息,并在onCreateViewHolder方法中调用该方法进行传递。例如:

代码语言:txt
复制
public class MyViewHolder extends RecyclerView.ViewHolder {
    public void setPosition(int position) {
        // 在这里可以使用传递进来的位置信息进行处理
    }
}

然后,在onCreateViewHolder方法中,我们创建ViewHolder对象后,调用setPosition方法传递位置信息:

代码语言:txt
复制
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View itemView = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
    MyViewHolder viewHolder = new MyViewHolder(itemView);
    viewHolder.setPosition(position);
    return viewHolder;
}

通过以上两种方式,我们可以将onBindViewHolder的位置信息传递给ViewHolder类,以便在ViewHolder类中进行相应的处理操作。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

基于滑动场景解析RecyclerView的回收复用机制原理

最近在研究 RecyclerView 的回收复用机制,顺便记录一下。我们知道,RecyclerView 在 layout 子 View 时,都通过回收复用机制来管理。网上关于回收复用机制的分析讲解的文章也有一大堆了,分析得也都很详细,什么四级缓存啊,先去 mChangedScrap 取再去哪里取啊之类的;但其实,我想说的是,RecyclerView 的回收复用机制确实很完善,覆盖到各种场景中,但并不是每种场景的回收复用时都会将机制的所有流程走一遍的。举个例子说,在 setLayoutManager、setAdapter、notifyDataSetChanged 或者滑动时等等这些场景都会触发回收复用机制的工作。但是如果只是 RecyclerView 滑动的场景触发的回收复用机制工作时,其实并不需要四级缓存都参与的。

06

Kotlin入门(23)适配器的进阶表达

前面在介绍列表视图和网格视图时,它们的适配器代码都存在视图持有者ViewHolder,因为Android对列表类视图提供了回收机制,如果某些列表项在屏幕上看不到了,则系统会自动回收相应的视图对象。随着用户的下拉或者上拉手势,已经被回收的列表项要重新加载到界面上,倘若每次加载都得从头创建视图对象,势必增加了系统的资源开销。所以ViewHolder便应运而生,它在列表项首次初始化时,就将其视图对象保存起来,后面再次加载该视图时,即可直接从持有者处获得先前的视图对象,从而减少了系统开销,提高了系统的运行效率。 视图持有者的设计理念固然美好,却苦了Android开发者,每次由BaseAdapter派生新的适配器类,都必须手工处理视图持有者的相关逻辑,实在是个沉重的负担。有鉴于此,循环视图的适配器把视图持有者的重用逻辑剥离出来,由系统自行判断并处理持有者的重用操作。开发者继承RecyclerView.Adapter之后,只要完成业务上的代码逻辑即可,无需进行BaseAdapter视图持有者的手工重用。 现在由Kotlin实现循环视图的适配器类,综合前面两小节提到的优化技术,加上视图持有者的自动重用,适配器代码又得到了进一步的精简。由于循环视图适配器并不提供列表项的点击事件,因此开发者要自己编写包括点击、长按在内的事件处理代码。为方便理解循环适配器的Kotlin编码,下面以微信的公众号消息列表为例,给出对应的消息列表Kotlin代码:

04
领券