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