Fragment基本概述

1.基本概念

1)它是什麼鬼,有什麼用?

答:Fragment是Android3.0後引入的一個新的API,他出現的初衷是爲了適應大屏幕的平板電腦, 
當然現在他仍然是平板APP UI設計的寵兒,而且我們普通手機開發也會加入這個Fragment, 
我們可以把他看成一個小型的Activity,又稱Activity片段!想想,如果一個很大的界面,我們 
就一個佈局,寫起界面來會有多麻煩,而且如果組件多的話是管理起來也很麻煩!而使用Fragment 
我們可以把屏幕劃分成幾塊,然後進行分組,進行一個模塊化的管理!從而可以更加方便的在 
運行過程中動態地更新Activity的用戶界面!另外Fragment並不能單獨使用,他需要嵌套在Activity 
中使用,儘管他擁有自己的生命週期,但是還是會受到宿主Activity的生命週期的影響,比如Activity 
被destory銷燬了,他也會跟着銷燬!

下圖是文檔中給出的一個Fragment分別對應手機與平板間不同情況的處理圖:

PS:簡單的新聞瀏覽頁面,使用兩個Fragment分別顯示新聞列表與新聞內容;


2)Fragment的生命週期圖


3)核心要點:

下面說下使用Fragment的一些要點:

  • 3.0版本後引入,即minSdk要大於11
  • Fragment需要嵌套在Activity中使用,當然也可以嵌套到另外一個Fragment中,但這個被嵌套 
    的Fragment也是需要嵌套在Activity中的,間接地說,Fragment還是需要嵌套在Activity中!! 
    受寄主Activity的生命週期影響,當然他也有自己的生命週期!另外不建議在Fragment裏面 
    嵌套Fragment因爲嵌套在裏面的Fragment生命週期不可控!!!
  • 官方文檔說創建Fragment時至少需要實現三個方法:onCreate( ),onCreateView( ),OnPause( ); 
    不過貌似只寫一個onCreateView也是可以的…
  • Fragment的生命週期和Activity有點類似:三種狀態: 
    Resumed:在允許中的Fragment可見 Paused:所在Activity可見,但是得不到焦點 
    Stoped: 
    ①調用addToBackStack(),Fragment被添加到Bcak棧 
    ②該Activity轉向後臺,或者該Fragment被替換/刪除 
    ps:停止狀態的fragment仍然活着(所有狀態和成員信息被系統保持着),然而,它對用戶 
    不再可見,並且如果activity被幹掉,他也會被幹掉.

4)Fragment的幾個子類:

ps:很多時候我們都是直接重寫Fragment,inflate加載佈局完成相應業務了,子類用的不多,等需要的 
時候在深入研究!

  • 對話框:DialogFragment
  • 列表:ListFragment
  • 選項設置:PreferenceFragment
  • WebView界面:WebViewFragment

5)是用App包下的Fragment還是v4包下的:

問題概述:

相信很多朋友在使用Fragment的時候都會遇到下面這種情況:

那麼我們到底是使用android.app下的Fragment還是用的android.support.v4.app包下 
的Fragment呢?

答:其實都可以,前面說過Fragment是Android 3.0(API 11)後引入的,那麼如果開發的app需要 
在3.0以下的版本運行呢?比如還有一點點市場份額的2.3!於是乎,v4包就這樣應運而生了, 
而最低可以兼容到1.6版本!至於使用哪個包看你的需求了,現在3.0下手機市場份額其實已經不多了,隨街都是4.0以上的,6.0十月份都出了,你說呢…所以這個時候,你可以直接使用app包下的Fragment 
然後調用相關的方法,通常都是不會有什麼問題的;如果你Fragment用了app包的, 
FragmentManager和FragmentTransaction都需要是app包的!要麼用全部用app,要麼全部用v4, 
不然可是會報錯的哦!當然如果你要自己的app對於低版本的手機也兼容的話,那麼就可以選擇用v4包!

使用v4包下Fragment要注意的地方:

  • ①如果你使用了v4包下的Fragment,那麼所在的那個Activity就要繼承FragmentActivity哦! 
    案例:今天在xml文件中靜態地載入fragment,然後重寫了Fragment,但是在加載Activity的時候就報錯了, 
    大概的提示就是Fragment錯誤還是找不到什麼的,name屬性改了幾次還是錯!最後才發現是用了 
    v4的包的緣故,只需讓自己的Activity改成FragmentActivity即可!
  • ②之前寫了下面這段代碼,然後報錯: 

    有點莫名其妙啊,Fragment,FragmentManager,FragmentTransaction都是用的v4包啊, 
    Activity也是繼承FragmentActivity的啊?都改成app包就可以了,但是這不和我們用v4包的 
    前提衝突了麼?其實也是有解決方法的哈? 
    答:只需要把getFragmentManager( )改成getSupportFragmentManager( )就可以了

2.創建一個Fragment

1)靜態加載Fragment

實現流程:

示例代碼:

Step 1:定義Fragment的佈局,就是fragment顯示內容的 
Step 2:自定義一個Fragment類,需要繼承Fragment或者他的子類,重寫onCreateView()方法 
在該方法中調用:inflater.inflate()方法加載Fragment的佈局文件,接着返回加載的view對象

<code class="language-Java hljs java has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">Fragmentone</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">extends</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">Fragment</span> {</span>
    <span class="hljs-annotation" style="color: rgb(155, 133, 157); box-sizing: border-box;">@Override</span>
    <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> View <span class="hljs-title" style="box-sizing: border-box;">onCreateView</span>(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment1, container,<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">false</span>);
        <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">return</span> view;
    }   
}</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li></ul>

Step 3:在需要加載Fragment的Activity對應的佈局文件中添加fragment的標籤, 
記住,name屬性是全限定類名哦,就是要包含Fragment的包名,如:

<code class="language-Java hljs applescript has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">    <fragment
        android:<span class="hljs-property" style="box-sizing: border-box;">id</span>=<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"@+id/fragment1"</span>
        android:<span class="hljs-property" style="box-sizing: border-box;">name</span>=<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"com.jay.example.fragmentdemo.Fragmentone"</span>
        android:layout_width=<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"match_parent"</span>
        android:layout_height=<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"0dp"</span>
        android:layout_weight=<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"1"</span> /></code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li></ul>

Step 4: Activity在onCreate( )方法中調用setContentView()加載佈局文件即可!


2)動態加載Fragment

實現流程:

示例代碼: 
這裏演示的是,當橫豎屏切換的時候地切換Fragment:

Fragment以及佈局代碼就不貼出來了,直接貼MainActivity的關鍵代碼:

<code class="language-Java hljs java has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-class" style="box-sizing: border-box;"><span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">class</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">MainActivity</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">extends</span> <span class="hljs-title" style="box-sizing: border-box; color: rgb(102, 0, 102);">Activity</span> {</span>

    <span class="hljs-annotation" style="color: rgb(155, 133, 157); box-sizing: border-box;">@Override</span>
    <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">protected</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> <span class="hljs-title" style="box-sizing: border-box;">onCreate</span>(Bundle savedInstanceState) {
        <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">super</span>.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Display dis = getWindowManager().getDefaultDisplay();
        <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">if</span>(dis.getWidth() > dis.getHeight())
        {
            Fragment1 f1 = <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">new</span> Fragment1();
            getFragmentManager().beginTransaction().replace(R.id.LinearLayout1, f1).commit();
        }

        <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">else</span>
        {
            Fragment2 f2 = <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">new</span> Fragment2();
            getFragmentManager().beginTransaction().replace(R.id.LinearLayout1, f2).commit();
        }
    }   
}</code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li><li style="box-sizing: border-box; padding: 0px 5px;">11</li><li style="box-sizing: border-box; padding: 0px 5px;">12</li><li style="box-sizing: border-box; padding: 0px 5px;">13</li><li style="box-sizing: border-box; padding: 0px 5px;">14</li><li style="box-sizing: border-box; padding: 0px 5px;">15</li><li style="box-sizing: border-box; padding: 0px 5px;">16</li><li style="box-sizing: border-box; padding: 0px 5px;">17</li><li style="box-sizing: border-box; padding: 0px 5px;">18</li><li style="box-sizing: border-box; padding: 0px 5px;">19</li><li style="box-sizing: border-box; padding: 0px 5px;">20</li></ul>

3.Fragment管理與Fragment事務


4.Fragment與Activity的交互

可能有的朋友不喜歡看圖,接下來用文字介紹下吧:

1)組件獲取

Fragment獲得Activity中的組件: getActivity().findViewById(R.id.list); 
Activity獲得Fragment中的組件(根據id和tag都可以):getFragmentManager.findFragmentByid(R.id.fragment1);


2)數據傳遞

①Activit傳遞數據給Fragment:

在Activity中創建Bundle數據包,調用Fragment實例的setArguments(bundle) 
從而將Bundle數據包傳給Fragment,然後Fragment中調用getArguments獲得 
Bundle對象,然後進行解析就可以了

②Fragment傳遞數據給Activity

在Fragment中定義一個內部回調接口,再讓包含該Fragment的Activity實現該回調接口, 
Fragment就可以通過回調接口傳數據了,回調,相信很多人都知道是什麼玩意,但是 
寫不出來啊,網上的一百度”fragment傳數據給Activity”,全是李剛老師的那個代碼,真心無語 
算了,這裏就寫下局部代碼吧,相信讀者一看就懂的了:

Step 1:定義一個回調接口:(Fragment中)

<code class="language-Java hljs cs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"> <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/*接口*/</span>  
    <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">interface</span> CallBack{  
        <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/*定義一個獲取信息的方法*/</span>  
        <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> <span class="hljs-title" style="box-sizing: border-box;">getResult</span>(String result);  
    }  </code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li></ul>

Step 2:接口回調(Fragment中)

<code class="language-Java hljs cs has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/*接口回調*/</span>  
    <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> <span class="hljs-title" style="box-sizing: border-box;">getData</span>(CallBack callBack){  
        <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/*獲取文本框的信息,當然你也可以傳其他類型的參數,看需求咯*/</span>  
        String msg = editText.getText().toString();  
        callBack.getResult(msg);  
    }  </code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li></ul>

Step 3:使用接口回調方法讀數據(Activity中)

<code class="language-Java hljs java has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;"><span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/* 使用接口回調的方法獲取數據 */</span>  
leftFragment.getData(<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">new</span> CallBack() {  
 <span class="hljs-annotation" style="color: rgb(155, 133, 157); box-sizing: border-box;">@Override</span>  
       <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">void</span> <span class="hljs-title" style="box-sizing: border-box;">getResult</span>(String result) {              <span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">/*打印信息*/</span>  
            Toast.makeText(MainActivity.<span class="hljs-keyword" style="color: rgb(0, 0, 136); box-sizing: border-box;">this</span>, <span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"-->>"</span> + result, <span class="hljs-number" style="color: rgb(0, 102, 102); box-sizing: border-box;">1</span>).show();  
            }
        });  </code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li></ul>

總結下方法: 
->在Fragment定義一個接口,接口中定義抽象方法,你要傳什麼類型的數據參數就設置爲什麼類型; 
->接着還有寫一個調用接口中的抽象方法,把要傳遞的數據傳過去 
->再接着就是Activity了,調用Fragment提供的那個方法,然後重寫抽象方法的時候進行數據 
的讀取就可以了!!!

③Fragment與Fragment之間的數據互傳

其實這很簡單,找到要接受數據的fragment對象,直接調用setArguments傳數據進去就可以了 
通常的話是replace時,即fragment跳轉的時候傳數據的,那麼只需要在初始化要跳轉的Fragment 
後調用他的setArguments方法傳入數據即可! 
如果是兩個Fragment需要即時傳數據,而非跳轉的話,就需要先在Activity獲得f1傳過來的數據, 
再傳到f2了,就是以Activity爲媒介~

示例代碼如下:

<code class="language-Java hljs avrasm has-numbering" style="display: block; padding: 0px; color: inherit; box-sizing: border-box; font-family: 'Source Code Pro', monospace;font-size:undefined; white-space: pre; border-radius: 0px; word-wrap: normal; background: transparent;">FragmentManager fManager = getSupportFragmentManager( )<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
FragmentTransaction fTransaction = fManager<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.beginTransaction</span>()<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
Fragmentthree t1 = new Fragmentthree()<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
Fragmenttwo t2 = new Fragmenttwo()<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
Bundle bundle = new Bundle()<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
bundle<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.putString</span>(<span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"key"</span>,id)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;</span>
t2<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.setArguments</span>(bundle)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">; </span>
fTransaction<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.add</span>(R<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.id</span><span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.fragmentRoot</span>, t2, <span class="hljs-string" style="color: rgb(0, 136, 0); box-sizing: border-box;">"~~~"</span>)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;  </span>
fTransaction<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.addToBackStack</span>(t1)<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;  </span>
fTransaction<span class="hljs-preprocessor" style="color: rgb(68, 68, 68); box-sizing: border-box;">.commit</span>()<span class="hljs-comment" style="color: rgb(136, 0, 0); box-sizing: border-box;">;  </span></code><ul class="pre-numbering" style="box-sizing: border-box; position: absolute; width: 50px; top: 0px; left: 0px; margin: 0px; padding: 6px 0px 40px; border-right-width: 1px; border-right-style: solid; border-right-color: rgb(221, 221, 221); list-style: none; text-align: right; background-color: rgb(238, 238, 238);"><li style="box-sizing: border-box; padding: 0px 5px;">1</li><li style="box-sizing: border-box; padding: 0px 5px;">2</li><li style="box-sizing: border-box; padding: 0px 5px;">3</li><li style="box-sizing: border-box; padding: 0px 5px;">4</li><li style="box-sizing: border-box; padding: 0px 5px;">5</li><li style="box-sizing: border-box; padding: 0px 5px;">6</li><li style="box-sizing: border-box; padding: 0px 5px;">7</li><li style="box-sizing: border-box; padding: 0px 5px;">8</li><li style="box-sizing: border-box; padding: 0px 5px;">9</li><li style="box-sizing: border-box; padding: 0px 5px;">10</li></ul>

5.走一次生命週期圖:

思前想後還是決定要帶大家簡單的走一趟生命週期圖,加深大家對Fragment生命週期的理解:

①Activity加載Fragment的時候,依次調用下面的方法: 
onAttach -> onCreate -> onCreateView -> onActivityCreated -> onStart ->onResume

②當我們弄出一個懸浮的對話框風格的Activity,或者其他,就是讓Fragment所在的Activity可見,但不獲得焦點 
onPause

③當對話框關閉,Activity又獲得了焦點: 
onResume

④當我們替換Fragment,並調用addToBackStack()將他添加到Back棧中 
onPause -> onStop -> onDestoryView 
!!注意,此時的Fragment還沒有被銷燬哦!!!

⑤當我們按下鍵盤的回退鍵,Fragment會再次顯示出來: 
onCreateView -> onActivityCreated -> onStart -> onResume

⑥如果我們替換後,在事務commit之前沒有調用addToBackStack()方法將 
Fragment添加到back棧中的話;又或者退出了Activity的話,那麼Fragment將會被完全結束, 
Fragment會進入銷燬狀態 
onPause -> onStop -> onDestoryView -> onDestory -> onDetach


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章