場景:使用Fragment實現(xiàn)切頁。
創(chuàng)新互聯(lián)服務(wù)項目包括東興網(wǎng)站建設(shè)、東興網(wǎng)站制作、東興網(wǎng)頁制作以及東興網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,東興網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到東興省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
類結(jié)構(gòu):
一:Activity
Activity中使用getSupportFragmentManager().beginTransaction()來填充一個Fragment(管理用的FragmentA)
Activity部分代碼:
FragmentA fragment = FragmentA.newInstant(null); getSupportFragmentManager().beginTransaction().add(R.id.f_tab_fragment,fragment).commit();
XML:
二:FragmentA
加載一個主FragmentA,作為管理其它子葉片F(xiàn)ragmentX。
現(xiàn)在比如有兩個子葉片F(xiàn)ragmentB、FragmentC.
FragmentA 使用FragmentManager和FragmentTransaction管理FragmentB、FragmentC的切換
FragmentA代碼:
public class FragmentA extends BaseFragment { private static final String TAB_HOME = com.timediffproject.module.home.MyMainFragment.class.getName(); private static final String TAB_TEST = com.timediffproject.module.home.TestFragment.class.getName(); private BaseFragment mLastShowFragment; private static TabFragment fragment; public static TabFragment newInstant(Bundle bundle){ if (fragment == null){ fragment = new TabFragment(); fragment.setArguments(bundle); } return fragment; } @Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); initTabInfo(); } private void initTabInfo(){ FragmentManager fm = getFragmentManager(); if (fm == null){ return; } FragmentTransaction ft = fm.beginTransaction(); BaseFragment home = (BaseFragment) fm.findFragmentByTag(TAB_HOME); if (home != null){ ft.hide(home); } BaseFragment test = (BaseFragment) fm.findFragmentByTag(TAB_TEST); if (test != null){ ft.hide(test); } ft.commit(); } @Nullable @Override public View onCreateView(LayoutInflater inflater,ViewGroup container,Bundle savedInstanceState) { return inflater.inflate(R.layout.fragment_tab,container,false); } @Override public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); view.findViewById(R.id.btn_change_home).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { switchTo(TAB_HOME,null); } }); view.findViewById(R.id.btn_change_test).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { switchTo(TAB_TEST,null); } }); switchTo(TAB_HOME,null); } //切換Fragment的方式(FragmentB、FragmentC) //tab為Fragment的類名(如:FragmentB.class.getName()) //R.id.fl_container是在Activity的布局里,不是在FragmentA的布局里 private void switchTo(String tab, Bundle bundle){ //初始化管理Fragment的類 FragmentManager fm = getFragmentManager(); if (fm == null){ return; } FragmentTransaction ft = fm.beginTransaction(); //從FragmentManager里尋找類名為tab的Fragment BaseFragment fragment = (BaseFragment)fm.findFragmentByTag(tab); if (fragment == null){ fragment = (BaseFragment) Fragment.instantiate(getActivity(),tab); fragment.setArguments(bundle); ft.add(R.id.fl_container,fragment,tab); }else{ ft.show(fragment); } //隱藏現(xiàn)在正顯示的Fragment if (mLastShowFragment != null) { ft.hide(mLastShowFragment); } //記錄最后點擊的Fragment mLastShowFragment = fragment; ft.commitAllowingStateLoss(); } }
XML:
<?xml version="1.0" encoding="utf-8"?>
三:FragmentX(FragmentB、FragmentC)
子頁的邏輯根據(jù)具體業(yè)務(wù)自己定義,實現(xiàn)與一般Fragmeng一樣
例如:
public class TestFragment extends BaseFragment { @Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_test,container,false); } @Override public void onViewCreated(View view, Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); } }
到這里,就可以簡單的實現(xiàn)-用底部Tab切換Fragment實現(xiàn)切頁的功能
附圖:
PS:實現(xiàn)過程中出現(xiàn)的錯誤
正確方式: 有關(guān)的fragment的初始化布局應(yīng)該加上false,與父類布局建立關(guān)系。
原因:不加的話這個inflater出來的view系統(tǒng)會綁定一個未知父類,這時候當(dāng)你把這個fragment又作為子頁綁定給Activity或者另一個fragment時,就會出現(xiàn)以上錯誤。
@Nullable @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { //這里正確的寫法是: //return inflater.inflate(R.layout.fragment_test,container,false); return inflater.inflate(R.layout.fragment_test,container); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。