方案一:使用Replace
1 private void replaceContainer(int position) {
2
3 FragmentTransaction transaction = fragmentManager.beginTransaction();
4 Fragment fragment = retrieveFromCache(position);
5 // fragment没有实例化过,new出一个添加到FragmentTransaction中,并且保存fragment的状态
6 if (null == fragment) {
7 try {
8 fragment =fragments.get(position).getClass().newInstance();
9 // transaction.addToBackStack(null);
10 } catch (Exception e) {
11 Log.e(TAG, "实例化菜单失败");
12 return;
13 }
14 }
15
16 transaction.replace(R.id.fl_infoRegister_inputlayout, fragment);
17 transaction.commit();
18 }
方案二:使用Hide
1 private int currentIndex = 0;//控制当前需要显示第几个Fragment
2 private ArrayList<Fragment> fragmentArrayList;//用List来存储Fragment,List的初始化没有写
3 private Fragment mCurrentFrgment;//显示当前Fragment
4
5
6 private void changeTab(int index) {
7 currentIndex = index;
8
9 FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
10 //判断当前的Fragment是否为空,不为空则隐藏
11 if (null != mCurrentFrgment) {
12 ft.hide(mCurrentFrgment);
13 }
14 //先根据Tag从FragmentTransaction事物获取之前添加的Fragment
15 Fragment fragment = getSupportFragmentManager().findFragmentByTag(fragmentArrayList.get(currentIndex).getClass().getName());
16
17 if (null == fragment) {
18 //如fragment为空,则之前未添加此Fragment。便从集合中取出
19 fragment = fragmentArrayList.get(index);
20 }
21 mCurrentFrgment = fragment;
22
23 //判断此Fragment是否已经添加到FragmentTransaction事物中
24 if (!fragment.isAdded()) {
25 ft.add(R.id.fragment, fragment, fragment.getClass().getName());
26 } else {
27 ft.show(fragment);
28 }
29 ft.commit();
30 }
在多个Fragmnet进行切换时,比如使用ListFragment时,会对多个Fragment进行操作,那么可以将这多个Fragment放到List中,当需要时,分别从List中取,对List的元素进行操作。
对于上述两种方案,更推荐使用方案二
对于方案一,同样也能实现多个Fragment进行切换,但是每次切换,都会重新加载一次Fragment的生命周期,
即会导致重新调用Fragment的onCreateView(),所以在切换页面时,就无法保存当前Fragment的状态。
如果使用方案二,使用add、hide、show的方式来进行Fragment的切换,通过findFragmentByTag(“”)的方法,
找到Fragment而不是重新新建实例add进容器,这样会不断重用已经实例化的Fragment,而不需要再重新创建新的Fragment,
并且在Fragment切换时,系统会调用 onHiddenChanged(boolean hidden)方法,可以通过重写在该方法中进行一些必要的操作。
参考:http://waylenw.github.io/Android/android-fragment-change-one/
|