前言
用過(guò)viewPage+Fragment的都知道當(dāng)切換頁(yè)面時(shí),當(dāng)頁(yè)面切換超過(guò)2頁(yè),上上個(gè)頁(yè)面會(huì)被銷(xiāo)毀,重新切換回去時(shí)fragment會(huì)重新創(chuàng)建。下面2種方法可以解決fragment重新創(chuàng)建數(shù)據(jù)重新加載的問(wèn)題。
一、setOffscreenPageLimit()
直接設(shè)置viewPage的setOffscreenPageLimit()。setOffscreenPageLimit()方法設(shè)置的默認(rèn)值是1。這個(gè)設(shè)置的值有兩層含義: 一是 ViewPager 會(huì)預(yù)加載幾頁(yè); 二是 ViewPager 會(huì)緩存 2*n+1 頁(yè)(n為設(shè)置的值)。setOffscreenPageLimit()可以簡(jiǎn)單粗暴的解決數(shù)據(jù)重新加載問(wèn)題。但是如果像今日頭條有多個(gè)Fragment呢?那就可以用Fragment懶加載了
二、Fragment懶加載
保證只有第一次創(chuàng)建時(shí)會(huì)加載數(shù)據(jù),代碼如下:
public abstract class LazyloadFragment extends Fragment {
private View mView;
private boolean hasLoadData = false; // 是否已加載數(shù)據(jù)
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
mView= inflater.inflate(R.layout.fragment_lazyload, null);
return mView;
}
@Override
public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
// 如果setUserVisibleHint()在mView 創(chuàng)建前調(diào)用時(shí),那么
// 就等到rootView創(chuàng)建完后才回調(diào)onFragmentVisibleChange(true)
// 保證onFragmentVisibleChange()的回調(diào)發(fā)生在mView 創(chuàng)建完成之后,防止mView == null
if (getUserVisibleHint()) {
if (!hasLoadData) {
// 一般是第一次打開(kāi)TabActivity頁(yè)面時(shí),當(dāng)前Fragment會(huì)走這里
loadData();
hasLoadData = true;
}
}
super.onViewCreated(view, savedInstanceState);
}
@Override
public void setUserVisibleHint(boolean isVisibleToUser) {
super.setUserVisibleHint(isVisibleToUser);
// setUserVisibleHint在初始化Fragment的時(shí)候也會(huì)調(diào)用,且在onCreateView之前,所以mView會(huì)為null
// mView是否初始化標(biāo)志,防止回調(diào)函數(shù)在mView為空的時(shí)候觸發(fā)
if (mView == null) {
return;
}
if (!hasLoadData && isVisibleToUser) {
loadData();
hasLoadData = true;
}
}
private void loadData(){
// 加載數(shù)據(jù)
}
}