😄作者简介: 小曾同学.com,一个致力于测试开发的博主⛽️,主要职责:测试开发、CI/CD,日常还会涉及Android开发工作。
如果文章知识点有错误的地方,还请大家指正,让我们一起学习,一起进步。
😊 座右铭:不想当开发的测试,不是一个好测试✌️。
热衷分享,喜欢原创,如果觉得博主的文章还不错的话,还请点赞、收藏哦!👍
前言 ✨
ListView 性能、扩展性不是很好,它只能实现数据纵向滚动的效果。RecyclerView 是 ListView 的进阶版,可以实现 ListView 的纵向滑动和横向滑动。
RecyclerView的基本用法🪐
-
需要在 build.gradle 中添加相应的依赖库
RecyclerView 属于新增控件,Google 将 RecyclerView控件定义在了
AndroidX
当中,只需要在项目的build.gradle
中添加RecyclerView
库的依赖,这样就能保证在所有Android 系统版本上都可以使用 RecycleView 控件。implementation "androidx.recyclerview:recyclerview:1.2.1"
-
修改布局文件
在布局文件中新增 RecyclerView 标签,因为 RecyclerView 并不是内置在系统 SDK 当中,所以需要把完整的包路径写出来,控件属性无非是 id 、宽、高。<androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent"/>
-
自定义适配器
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 的具体简单实践。