程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了如果使用喷气背包导航方法大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决如果使用喷气背包导航方法?

开发过程中遇到如果使用喷气背包导航方法的问题如何解决?下面主要结合日常开发的经验,给出你关于如果使用喷气背包导航方法的解决方法建议,希望对你解决如果使用喷气背包导航方法有所启发或帮助;

我正在使用一个显示 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中删除方法的数据库访问方法 片段视图模型

    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" />

现在发生的是,当我按下删除按钮时,它返回到主片段,如果我按下后退按钮,它将不再返回对话框片段,所以一切正常,但问题是,它根本不会删除该项目。如何删除回收站视图中的项目并防止后退按钮访问后堆栈中的已删除对话框片段?我已经上下阅读了 backstack 的处理,并浏览了很多关于处理 backstack 和 back 按钮的页面,但没有任何效果。我错过了一些明显的东西吗?感谢您的帮助。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

大佬总结

以上是大佬教程为你收集整理的如果使用喷气背包导航方法全部内容,希望文章能够帮你解决如果使用喷气背包导航方法所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: