android - 在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"
我怎样才能做到这一点?
解决方案
感谢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
}
推荐阅读
- python - 如何在 python 中从 pywikibot 获取重定向
- verilog - 在 Verilog 中增加一个变量以索引导线(使用循环)
- python-3.x - 如何关闭 PRAW Reddit 实例?
- reactjs - 出现在组件上方的 Material UI Select 按钮标签
- python - Python函数以挂起的程序结束
- java - Spring Batch如何使用具有其他对象列表的对象持久化到数据库中
- windows - 在 Enclave 中加载 DLL 失败并显示 ERROR_INVALID_IMAGE_HASH
- python - 处理 POST 请求的简单 Python 代理服务器
- html - 以线性梯度作为后备的圆锥梯度
- sml - 冒泡排序实现中的无限循环