首页 > 解决方案 > 在Kotlin中将数据从recyclerview发送到没有intarface的片段

问题描述

我正在学习 kotlin,并且对 recyclerview 感到困惑。任务很简单:显示来自在片段内单击的回收器(内部活动)项目的数据。

该模型:

data class MyModel (
val info1:String,
val info2:String,
val info3:String)

recyclerView是使用我在安东尼奥的书中看到的想法(android开发人员的kotlin)实现的 - 没有使用intarface

class RecyclerAdapter(
val myList:List<MyModel>,
val listener:(MyModel)->Unit):RecyclerView.Adapter<RecyclerAdapter.MyViewHolder>() {


override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder {
    val itemViewholder = LayoutInflater.from(parent.context).inflate(R.layout.recycler_item,parent,false)
    return MyViewHolder(itemViewholder)
}

override fun onBindViewHolder(holder: MyViewHolder, position: Int) {
    holder.bind(myList[position],listener)
}

override fun getItemCount(): Int {
    return myList.count()
}

class MyViewHolder(itemView:View):RecyclerView.ViewHolder(itemView){

    fun bind(list:MyModel,itemListener: (MyModel) -> Unit) = with(itemView){
        recycler_infor1.text = list.info1
        recicler_infor2.text = list.info2
        setOnClickListener { itemListener(list) }
    }
}}

在活动中:

with(my_recyclerView){
        layoutManager = LinearLayoutManager(this@MainActivity,RecyclerView.VERTICAL,false)
        setHasFixedSize(true)
        adapter = RecyclerAdapter(fakeItens()){
            supportFragmentManager.commit {
                replace(R.id.fragment_container,FragmentDetail()).addToBackStack(null)
            }
        }

}

当应用程序运行时,recyclerView每个项目中也会显示第一个和第二个信息。现在,我需要在具有三个的 Fragment 中显示这些信息和第三个信息textView

android:id="@+id/frag_infor1"
android:id="@+id/frag_infor2"
android:id="@+id/frag_infor3"

我怎样才能做到这一点?

标签: androidkotlinandroid-fragmentsandroid-recyclerviewadapter

解决方案


感谢null_override,我找到了解决方案:

1 - 制作MyModel Parcelable

data class MyModel(val info1:String?,
                   val info2:String?,
                   val info3:String?
):Parcelable {
    constructor(parcel: Parcel) : this(
        parcel.readString(),
        parcel.readString(),
        parcel.readString()
    )


    override fun writeToParcel(parcel: Parcel, flags: Int) {
        parcel.writeString(info1)
        parcel.writeString(info2)
        parcel.writeString(info3)
    }

    override fun describeContents(): Int {
        return 0
    }

    companion object CREATOR : Parcelable.Creator<MyModel> {
        override fun createFromParcel(parcel: Parcel): MyModel {
            return MyModel(parcel)
        }

        override fun newArray(size: Int): Array<MyModel?> {
            return arrayOfNulls(size)
        }
    }

}

2 - 传递给bundle并设置参数以在两者中Fragment使用apply

with(my_recyclerView){
            layoutManager = LinearLayoutManager(this@MainActivity,RecyclerView.VERTICAL,false)
            setHasFixedSize(true)
            adapter = RecyclerAdapter(fakeItens()){
                val bundle = Bundle().apply { putParcelable("Key", it) }
                supportFragmentManager.commit {
                    replace(R.id.fragment_container,FragmentDetail().apply { arguments = bundle }).addToBackStack(null)
                }
            }

        }

3 - 获取数据Fragment

lateinit var data:MyModel
override fun onAttach(context: Context) {
     super.onAttach(context)
     arguments?.getParcelable<MyModel>("Key").let {
          if (it != null) {
              data = it
          }
           
      }
  }

4 - 绑定views

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)
        frag_infor1.text = data.info1
        frag_infor2.text = data.info2
        frag_infor3.text = data.info3
}

推荐阅读