![](/img/trans.png)
[英]Delete an Item from the Recyclerview + Local database [Kotlin]
[英]Delete item from recyclerview on button click - Kotlin MVVM Firestore
当用户单击回收站视图中的删除按钮时,我无法从 Firestore 集合中删除数据。 我可以从 recyclerview 中删除它而没有任何问题,但是我无法在适配器、视图模型和处理 Firestore 操作的存储库之间建立连接。
在我的适配器中,我从 recyclerview 中删除了用户单击的项目:
class ArticleAdapter : RecyclerView.Adapter<ArticleAdapter.ViewHolder>() {
var data = mutableListOf<Product>()
set(value) {
field = value
notifyDataSetChanged()
}
override fun getItemCount() = data.size
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
val item = data[position]
holder.bind(item)
holder.deleteButton.setOnClickListener {
data.removeAt(position)
notifyDataSetChanged()
}
} ...
在对我的视图模型中的 Firestore 集合进行查询后,将填充 recyclerview:
class ArticleViewModel(private val repository: ProductRepository) : ViewModel() {
var savedProducts: MutableLiveData<MutableList<Product>> = MutableLiveData<MutableList<Product>>()
init {
savedProducts = getProducts()
}
fun getProducts(): MutableLiveData<MutableList<Product>> {
repository.getProducts().addSnapshotListener(EventListener<QuerySnapshot> { value, e ->
if (e != null) {
savedProducts.value = null
return@EventListener
}
val savedProductsList: MutableList<Product> = mutableListOf()
for (doc in value!!) {
val item = doc.toObject(Product::class.java)
item.id = doc.id
savedProductsList.add(item)
}
savedProductsList.sortBy { i -> i.productName }
savedProducts.value = savedProductsList
})
return savedProducts
} }
在我的 Fragment 中,我观察到 savedProducts 可能发生的任何变化:
class ArticleOverviewFragment : Fragment(), KodeinAware {
override val kodein: Kodein by kodein()
private val factory: ArticleViewModelFactory by instance()
private lateinit var viewModel: ArticleViewModel
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
val binding: FragmentArticleOverviewBinding =
DataBindingUtil.inflate(inflater, R.layout.fragment_article_overview, container, false)
viewModel = ViewModelProviders.of(this, factory).get(ArticleViewModel::class.java)
binding.viewModel = viewModel
val adapter = ArticleAdapter()
binding.recyclerViewGoods.adapter = adapter
viewModel.savedProducts.observe(viewLifecycleOwner, Observer {
it?.let {
adapter.data = it
}
})
...
} }
有没有一种方法可以在我的适配器中观察/保存已删除项目的 ID,并将该 ID 从适配器“传输”到 UI,只要填充了包含 ID 的字段,我就会在视图模型中调用 function 声明? 或者我应该直接从适配器访问视图模型? 怎么说呢,感觉有点不对...
声明一个局部变量
var removedPosition : Int ? = null
然后将此变量更新为 deleteButton 的 onClick 事件
holder.deleteButton.setOnClickListener {
data.removeAt(position)
removedPosition = position
notifyDataSetChanged()
}
请在 Adapter ( ArticleAdapter
) 中创建一种方法
fun getRemoveItemPosition() : Int {
var position = removedPosition
return position;
}
它返回已删除项目的 position 并在 UI( ArticleOverviewFragment
)中调用该方法,您需要从 recyclerview 获取已删除项目的 position
var removedItemPosition = adapter.getRemoveItemPosition()
现在您将使用名为removedItemPosition
的变量获得删除项目 Position 的值
ArticleViewModel
)中声明的 function 以删除 firestore 集合中的特定项目。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.