ViewPager+Fragment LazyLoad最優(yōu)解

ViewPager+Fragment的模式再常見不過了征峦,以國民應(yīng)用微信為例,假設(shè)微信也是ViewPager+Fragment的實(shí)現(xiàn)方式消请,那表現(xiàn)形式上就是一個(gè)ViewPager管理了四個(gè)Fragment栏笆,左右滑動(dòng)來回切換。但是ViewPager有一個(gè)奇葩的特性叫:預(yù)加載臊泰,比如打開微信蛉加,首先看到的是第一個(gè)Tab(微信),但事實(shí)上第二個(gè)Tab(通訊錄)已經(jīng)加載好了缸逃。當(dāng)選擇第二個(gè)Tab(通訊錄)七婴,第三個(gè)Tab(發(fā)現(xiàn))已經(jīng)加載好了蜕劝,以此類推嘹狞。
但上訴ViewPager+Fragment的這種組合并不完美有勾,因?yàn)槲蚁M脩暨x擇了哪個(gè)Tab再去加載哪個(gè)Tab的數(shù)據(jù),而不要去做預(yù)加載贺辰,假如當(dāng)前頁面和預(yù)加載頁面都有大量的網(wǎng)絡(luò)請求,可能就會(huì)比較慢嵌施,有很多請求在排隊(duì)饲化。關(guān)于這個(gè)問題,也有很偏激的做法吗伤,比如棄用ViewPager吃靠,自己手動(dòng)管理Fragment,或者直接禁掉ViewPager預(yù)加載足淆。有一種比較合適的方案是保持ViewPager預(yù)加載的特性巢块,但是只初始化View,選擇當(dāng)前Tab的時(shí)候再進(jìn)行網(wǎng)絡(luò)請求巧号。關(guān)于這一方案的實(shí)現(xiàn)族奢,也是眾說紛紜,千奇百怪丹鸿。最后越走,還是選擇男神Stay的方案。
直接上代碼靠欢。

public abstract class BasePageFragment extends Fragment {

    protected boolean isViewInitiated;
    protected boolean isVisibleToUser;
    protected boolean isDataInitiated;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        isViewInitiated = true;
        prepareFetchData();
    }

    @Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        this.isVisibleToUser = isVisibleToUser;
        prepareFetchData();
    }

    public abstract void fetchData();

    public boolean prepareFetchData() {
        return prepareFetchData(false);
    }

    public boolean prepareFetchData(boolean forceUpdate) {
        if (isVisibleToUser && isViewInitiated && (!isDataInitiated || forceUpdate)) {
            fetchData();
            isDataInitiated = true;
            return true;
        }
        return false;
    }

}

這是一個(gè)父類廊敌,看代碼這里只有一個(gè)setUserVisibleHint需要說下,這是一個(gè)相當(dāng)生僻的方法门怪,我們可以用這個(gè)方法來判斷當(dāng)前UI是否可見骡澈,所以在prepareFetchData方法里我們做如下判斷:就是當(dāng)前UI可見,并且fragment已經(jīng)初始化完畢掷空,如果網(wǎng)絡(luò)數(shù)據(jù)未加載秧廉,那么請求數(shù)據(jù)伞广,或者需要強(qiáng)制刷新頁面,那么也去請求數(shù)據(jù)疼电,So easy嚼锄。子Fragment只需要繼承父類,實(shí)現(xiàn)抽象方法蔽豺,在fetchData()里做網(wǎng)絡(luò)請求或者其他耗時(shí)操作即可区丑。再在寫個(gè)子類吧。

public class PageFragment extends BasePageFragment {
    
    public static PageFragment newInstance(String title){
        PageFragment fragment = new PageFragment();
        Bundle args = new Bundle();
        args.putString("key_fragment_title", title);
        fragment.setArguments(args);
        return fragment;
    }

    private String title;
    private TextView tv;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        title = getArguments().getString("key_fragment_title");
        Trace.d(title + ":onCreate");
    }
    
    @Override
    public void onResume() {
        super.onResume();
        Trace.d(title + ":onResume");
    }
    
    
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        Trace.d(title + ":onCreateView");
        tv = new TextView(getActivity());
        return tv;
    }

    @Override
    public void fetchData() {
        tv.setText(title);
        /** * 在這里請求網(wǎng)絡(luò)修陡。 */
    }
        
}

如果你也有這樣的需求或者煩惱沧侥,保證藥到病除。

有同學(xué)說實(shí)踐過程中遇到了些問題魄鸦,比如Fragment只刷新一次宴杀,這個(gè)問題只要手動(dòng)調(diào)用prepareFetchData(),傳true即可強(qiáng)制刷新了拾因。還有同學(xué)質(zhì)疑setUserVisibleHint()和onActivityCreated()的執(zhí)行先后的問題旺罢。關(guān)于這個(gè)請看下圖。

1.jpg
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末扁达,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蠢熄,更是在濱河造成了極大的恐慌跪解,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,692評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件签孔,死亡現(xiàn)場離奇詭異叉讥,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)饥追,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評論 3 392
  • 文/潘曉璐 我一進(jìn)店門节吮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人判耕,你說我怎么就攤上這事透绩。” “怎么了壁熄?”我有些...
    開封第一講書人閱讀 162,995評論 0 353
  • 文/不壞的土叔 我叫張陵帚豪,是天一觀的道長。 經(jīng)常有香客問我草丧,道長狸臣,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,223評論 1 292
  • 正文 為了忘掉前任昌执,我火速辦了婚禮烛亦,結(jié)果婚禮上诈泼,老公的妹妹穿的比我還像新娘。我一直安慰自己煤禽,他們只是感情好铐达,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,245評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著檬果,像睡著了一般瓮孙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上选脊,一...
    開封第一講書人閱讀 51,208評論 1 299
  • 那天杭抠,我揣著相機(jī)與錄音,去河邊找鬼恳啥。 笑死偏灿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钝的。 我是一名探鬼主播翁垂,決...
    沈念sama閱讀 40,091評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼扁藕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起疚脐,我...
    開封第一講書人閱讀 38,929評論 0 274
  • 序言:老撾萬榮一對情侶失蹤亿柑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后棍弄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體望薄,經(jīng)...
    沈念sama閱讀 45,346評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,570評論 2 333
  • 正文 我和宋清朗相戀三年呼畸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了痕支。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,739評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蛮原,死狀恐怖卧须,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情儒陨,我是刑警寧澤花嘶,帶...
    沈念sama閱讀 35,437評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站蹦漠,受9級特大地震影響椭员,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜笛园,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,037評論 3 326
  • 文/蒙蒙 一隘击、第九天 我趴在偏房一處隱蔽的房頂上張望侍芝。 院中可真熱鬧,春花似錦埋同、人聲如沸州叠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽留量。三九已至,卻和暖如春哟冬,著一層夾襖步出監(jiān)牢的瞬間楼熄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評論 1 269
  • 我被黑心中介騙來泰國打工浩峡, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留可岂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,760評論 2 369
  • 正文 我出身青樓翰灾,卻偏偏與公主長得像缕粹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子纸淮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,647評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,082評論 25 707
  • 2017年05月30 最后的懶加載寫的不好平斩,推薦請叫我大蘇同學(xué)寫的Fragment懶加載博客,【Android】再...
    英勇青銅5閱讀 13,409評論 56 189
  • 死磕 Fragment 的生命周期 本文原創(chuàng)咽块,轉(zhuǎn)載請注明出處绘面。歡迎關(guān)注我的 簡書 ,關(guān)注我的專題 Android ...
    MeloDev閱讀 6,996評論 43 105
  • ViewPager顯示多Fragment使用問題 前言:每當(dāng)使用ViewPager時(shí)侈沪,對于選用什么適配器揭璃,緩存多少...
    xlsong閱讀 40,895評論 2 62
  • 在北京城里的公路已經(jīng)從二環(huán)向外擴(kuò)張到五環(huán)六環(huán)。每一環(huán)都有各自的風(fēng)景亭罪。我以為最美的當(dāng)數(shù)二環(huán)路瘦馍!與二環(huán)并行的護(hù)城河,同...
    魚戲荷葉間閱讀 712評論 4 3