您的位置:首页 > 其它

多个Fragment切换时不重新实例化的方法

2017-02-06 12:04 309 查看

在项目中需要进行Fragment的切换,一直都是用replace()方法来替换Fragment:
public void switchContent(Fragment fragment) {
if(mContent != fragment) {
mContent = fragment;
mFragmentMan.beginTransaction()
.setCustomAnimations(android.R.anim.fade_in, R.anim.slide_out)
.replace(R.id.content_frame, fragment) // 替换Fragment,实现切换
.commit();
}
}


但是,这样会有一个问题:
每次切换的时候,Fragment都会重新实例化,重新加载一边数据,这样非常消耗性能和用户的数据流量。

就想,如何让多个Fragment彼此切换时不重新实例化?

翻看了Android官方Doc,和一些组件的源代码,发现,replace()这个方法只是在上一个Fragment不再需要时采用的简便方法。

正确的切换方式是
add()
,切换时
hide()
add()
另一个Fragment;再次切换时,只需hide()当前,show()另一个。

这样就能做到多个Fragment切换不重新实例化:

onCreate里面:

pickerFragment = new DeckPickerFragment();
fm = getFragmentManager();
baseFragment = fm.findFragmentById(R.id.fragment_main2);

ft = fm.beginTransaction();
ft.add(R.id.fragment_main2, pickerFragment);//此处需用add,不能用replace
ft.commit();
mContent = pickerFragment;
切换的方法:

private Fragment mContent = null;

/**
* 修改显示的内容 不会重新加载
* to 下一个fragment
* mContent 当前的fragment
*/
private void switchContent(Fragment to) {
if (mContent != to) {
FragmentTransaction transaction = getFragmentManager().beginTransaction();
if (!to.isAdded()) { // 判断是否被add过
// 隐藏当前的fragment,将 下一个fragment 添加进去
transaction.hide(mContent).add(R.id.fragment_main2, to).commit();

} else {
// 隐藏当前的fragment,显示下一个fragment
transaction.hide(mContent).show(to).commit();

}
mContent = to;

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: