navigation - 如果使用 jetpacks 导航方法,使用连接的 Room 数据库进行 Backstack 处理不会删除对话框片段中的项目
问题描述
我正在使用一个显示 iems 列表的 recyclerview。每个项目都有一个实现的 onlonglicklistener ,可以通过将项目发送到对话框(即另一个片段)来删除项目。在对话框中,用户可以只按是或否,如果他确定要删除该项目。那是适配器的代码:
适配器
private fun navigateToDelete(note: NoteEntry, view: View) {
// navigate from mainfragment to the dialogfragment via safeargs
val directionToDelete = MainFragmentDirections.actionMainFragmentToDialogFragment(note.noteId)
view.findNavController().navigate(directionToDelete)
}
现在,如果用户在对话框中接受删除,他将单击按钮。理论上,按钮获取视图模型并删除注释,然后将用户发送回主片段。
片段 binding.buttonDeleteDialog.setOnClickListener {
//delete the Item
dialogFragmentViewModel.deleteItem()
// navigate back to main Fragment
this.findNavController()
.navigate(DialogDeleteFragmentDirections.actionDialogFragmentToMainFragment())
}
这是viewmodel Fragments Viewmodel中删除方法的数据库访问方法
private suspend fun deleteTargetItem(item: Item{
dataSource.delete(item)
}
fun deleteItem() {
viewModelScope.launch {
val item= dataSource.getTargetItem(itemKey)
deleteTargetItem(item)
}
}
现在,当我像这样设置所有内容时,它可以完美运行。但是如果我按下后退按钮,我将再次发送到对话框片段,如果我再次按下删除按钮,整个应用程序将崩溃,因为数据库条目已被删除。因此,我想通过在导航图中使用此代码从后台堆栈中排除对话框片段来调整后台堆栈,以防止后退按钮返回该对话框片段。导航 xml
<action
android:id="@+id/action_dialogFragment_to_mainFragment"
app:destination="@id/mainFragment"
app:launchSingleTop="true"
app:popUpTo="@id/mainFragment"
app:popUpToInclusive="true" />
现在发生的事情是,当我按下删除按钮时,它会返回主片段,如果我按下后退按钮,它将不再进入对话框片段,所以一切正常,但问题是,它根本不删除该项目。如何删除recyclerview中的项目并防止后退按钮访问backstack中的deletedialog片段?我已经阅读了 backstack up 和 down 的处理,并浏览了很多关于处理 backstack 和 back 按钮的页面,但没有任何效果。我错过了一些明显的东西吗?谢谢你的帮助。
解决方案
推荐阅读
- javascript - PHP表单提交下载失败时如何向客户端发送消息
- python - 是否有任何与 python 的 mlab.psd 等效的 R 函数?
- r - 将整洁的选择参数转换为字符向量
- reactjs - 将 Cloudinary React 组件与 Bootrap React 用于图像
- java - 我可以使用 spring 批处理编写器来处理 HTTP 发布请求和写入数据库吗
- c - 从“int (int *)”分配给“void (*)(void *)”的不兼容指针类型
- android - 尝试查询与 ES 文件资源管理器等第三方应用程序关联的 uri 时出现 SecurityException
- perl - Perl 的 PSGI/Plack 和流式响应内容
- node.js - React + Next : 不从服务器端发送 cookie 到后端
- python - 使用 find_all 通过 BeautifulSoup 在 BS4 中查找某个类