方案一:使用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/