RecyclerView的具体实践,不相信你看不懂

😄作者简介: 小曾同学.com,一个致力于测试开发的博主⛽️,主要职责:测试开发、CI/CD,日常还会涉及Android开发工作。
如果文章知识点有错误的地方,还请大家指正,让我们一起学习,一起进步。
😊 座右铭:不想当开发的测试,不是一个好测试✌️。
热衷分享,喜欢原创,如果觉得博主的文章还不错的话,还请点赞、收藏哦!👍

前言 ✨

ListView 性能、扩展性不是很好,它只能实现数据纵向滚动的效果。RecyclerView 是 ListView 的进阶版,可以实现 ListView 的纵向滑动和横向滑动。

RecyclerView的基本用法🪐

  1. 需要在 build.gradle 中添加相应的依赖库

    RecyclerView 属于新增控件,Google 将 RecyclerView控件定义在了AndroidX当中,只需要在项目的build.gradle中添加 RecyclerView 库的依赖,这样就能保证在所有Android 系统版本上都可以使用 RecycleView 控件。

    implementation "androidx.recyclerview:recyclerview:1.2.1"
    
  2. 修改布局文件
    在布局文件中新增 RecyclerView 标签,因为 RecyclerView 并不是内置在系统 SDK 当中,所以需要把完整的包路径写出来,控件属性无非是 id 、宽、高。

    <androidx.recyclerview.widget.RecyclerView    
    	android:id="@+id/recyclerView"    
    	android:layout_width="match_parent"    
    	android:layout_height="match_parent"/>
    
  3. 自定义适配器

    ListView 适配器继承 ArrayAdapter 适配器,而 RecyclerView 中的适配器继承 RecyclerView.Adapter ,并将适配器类型指定为 FruitAdapter.ViewHolder, 而 ViewHolder 是我们在 fruitAdapter 中定义的一个内部类。

    class FruitAdapter (val fruitList:List<Fruit>):
        RecyclerView.Adapter<FruitAdapter.ViewHolder>(){
        inner class ViewHolder(view: View): RecyclerView.ViewHolder(view){
            val  fruitImage: ImageView = view.findViewById(R.id.fruitImage)
            val fruitName: TextView = view.findViewById(R.id.fruitName)
    
        }
        override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
    
            val view = LayoutInflater.from(parent.context)
                .inflate(R.layout.fruit_item, parent, false)
            return ViewHolder(view)
        
        }
    
        override fun onBindViewHolder(holder: ViewHolder, position: Int) {
            val fruit = fruitList[position]//获取当前项的Fruit实例
            holder.fruitImage.setImageResource(fruit.imageId)
            holder.fruitName.text = fruit.name
        }
    
        override fun getItemCount()=fruitList.size
    
    }
    

    首先定义一个内部类,然后让它继承 RecyclerView.ViewHolder,ViewHolder 的主构造函数中要传入一个 View 参数,这个参数通常是 RecyclerView 子项的最外层布局,然后就可以通过findViewById() 方法获取布局中的 textView 等实例。
    主要有三个方法 onCreateViewHolder() 、onBindViewHolder()、getItemCount()主要包括创建ViewHolder,绑定数据以及获取数据项数量,具体的详细解释可查看这里 Kotlin 实现 RecyclerView 适配器的标准写法
    以上就是 RecyclerView 的具体简单实践。

在这里插入图片描述

  • 9
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小曾同学.com

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值