我将自己的Android应用移植到honeycomb上,为了使用fragments,我做了一次大的重构。在我以前的版本中,当我按下Home按钮时,我用来执行ACTIVITY_CLEAR_TOP以重置back堆栈。

现在我的应用程序只是一个具有多个片段的单个活动,所以当我按下Home按钮时,我只是替换其中一个片段。我如何才能清除我的后台堆栈,而不必使用startActivity与ACTIVITY_CLEAR_TOP标志?


当前回答

这里的kotlin人

repeat(supportFragmentManager.backStackEntryCount) {
    supportFragmentManager.popBackStack()
}

其他回答

工作为我和简单的方法不使用循环:

 FragmentManager fragmentManager = getSupportFragmentManager();
 //this will clear the back stack and displays no animation on the screen
 fragmentManager.popBackStackImmediate(null, FragmentManager.POP_BACK_STACK_INCLUSIVE);

在尊重所有相关方的前提下;我非常惊讶地看到你们中有多少人可以用一个简单的方法清除整个片段返回堆栈

调频。popBackStack (null, FragmentManager.POP_BACK_STACK_INCLUSIVE);

根据Android文档(关于name参数-在声称的工作建议中的“null”)。

如果为空,则只弹出顶部状态

现在,我确实意识到我对你的特定实现缺乏了解(比如在给定的时间点你在后台堆栈中有多少项),但当我期待在更广泛的设备和供应商上有良好定义的行为时,我会把我所有的钱都押在公认的答案上:

(作为参考,和这个一起)

FragmentManager fm = getFragmentManager(); // or 'getSupportFragmentManager();'
int count = fm.getBackStackEntryCount();
for(int i = 0; i < count; ++i) {    
    fm.popBackStack();
}

清除无循环的backstack

String name = getSupportFragmentManager().getBackStackEntryAt(0).getName();
getSupportFragmentManager().popBackStack(name, FragmentManager.POP_BACK_STACK_INCLUSIVE);

addToBackStack()参数的名称在哪里

getSupportFragmentManager().beginTransaction().
                .replace(R.id.container, fragments.get(titleCode))
                .addToBackStack(name)

我只想补充一点:——

使用下面的方法从后台弹出

fragmentManager.popBackStack()

只是从交易中删除片段,不可能从屏幕上删除片段。 理想情况下,你可能看不见,但可能有两三个片段堆叠在一起,按下后退键UI可能看起来很杂乱,堆叠。

举个简单的例子:-

假设你有一个fragmentA,它使用fragmentmanager.replace()加载Fragmnet B,然后我们执行addToBackStack来保存这个事务。 所以流程是:——

step1 -> FragmentA->FragmentB(我们移动到FragmentB,但FragmentA在背景中,不可见)。

现在你在fragmentB中做了一些工作,并按下Save按钮——保存后应该回到fragmentA。

在FragmentB保存时,我们返回FragmentA。

常见的错误是……在Fragment B中,我们将执行Fragment Manager.replace() fragmentB与fragmentA。

但实际发生的是,我们再次载入片段A,取代片段b。所以现在有两个FragmentA(一个来自step1,一个来自step3)。

FragmentsA的两个实例堆叠在一起,它们可能不可见,但确实存在。

因此,即使我们通过上述方法清除了后台堆栈,也会清除事务,但不会清除实际的片段。 所以理想情况下,在按下保存按钮时,你只需要通过简单地执行fm.popBackStack()或fm.popBackImmediate()返回fragmentA。

所以纠正Step3-> fm.popBackStack()回到fragmentA,它已经在内存中了。

嗨~我找到了一个更好的解决方案,来自:https://gist.github.com/ikew0ng/8297033

    /**
 * Remove all entries from the backStack of this fragmentManager.
 *
 * @param fragmentManager the fragmentManager to clear.
 */
private void clearBackStack(FragmentManager fragmentManager) {
    if (fragmentManager.getBackStackEntryCount() > 0) {
        FragmentManager.BackStackEntry entry = fragmentManager.getBackStackEntryAt(0);
        fragmentManager.popBackStack(entry.getId(), FragmentManager.POP_BACK_STACK_INCLUSIVE);
    }
}