我又来了,哈哈。由于项目中用到了懒加载,以前也用过一次,可是原理没有弄懂只记的大概。 因此特地写了篇文章,但愿能够加深印象,要是可以帮助不是很了解的小伙伴那就更好了。废话很少少了,进入正题。git
咱们在作项目的时候常常会用到ViewPager+TabLayout做为页面切换。而切换的内容就是Fragment。但是有一个问题就是ViewPager为了节省用户等待时间,默认的会预加载左右各一个页面(能够根据 viewPager.setOffscreenPageLimit(limit)来设定)。 当我打开为Page1的时候,其实Page0,和Page2。已经生成,而且会执行onAttach->->->onResume期间的方法。若是有大量的操做的话,可能会致使卡顿。所以,有的人会想当我滑动到哪一个页面的时候,在执行我想要的网络请求操做。因此才会有了懒加载!github
要搞懂懒加载,就要弄清楚Fragment的生命周期。这里为了方便你们观察我在这里传入一张Fragment的生命周期图。网络
这里我写了个Demo,为了更加方便你们观察。如图:ide
第一个执行的不是咱们熟知的onAttach方法。而是setUserVisibleHint方法。这个方法就是懒加载的关键。在使用ViewPager生成Fragment的时候会预先调用这个方法,告诉用户该界面是否可见。以后才会正常执行到onResume生命周期。由于咱们预加载了page1页面,因此page1页面也执行到了onResume方法。spa
2.当滑动到Page1的时候code
Page1已经预加载完毕。执行Page1的setUserVisibleHint方法,而且visible为true便可见cdn
Page0隐藏。执行Page0的setUserVisibleHint方法,而且visible为false即不可见blog
Page2预加载。执行Page2的setUserVisibleHint直至onResume方法,而且visible为false即不可见。生成Page2,为不可见生命周期
3.当滑动到Page2的时候文档
Page2已经预加载完毕。执行Page2的setUserVisibleHint方法,而且visible为true便可见
Page1隐藏。执行Page1的setUserVisibleHint方法,而且visible为false即不可见
Page3预加载。执行Page3的setUserVisibleHint方法,而且visible为false即不可见。生成Page3,为不可见
Page0销毁。执行onPause->onStop->onDestroyView;
4.Page2的生命周期
经过两个变量,来判断是否须要懒加载。具体实现方法以下,固然最好的状况是各位本身根据Fragment的生命周期去写。
public abstract class BaseFragment extends Fragment {
//该Fragment是否建立过
private boolean isCreated = false;
//该Fragment是否初始过
private boolean isInit = false;
@Override
public void setUserVisibleHint(boolean isVisibleToUser) {
super.setUserVisibleHint(isVisibleToUser);
if (isCreated && isVisibleToUser && !isInit) {
Initialize();
isInit = true;
}
}
@Override
public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
super.onViewCreated(view, savedInstanceState);
isCreated = true;
if (isCreated && getUserVisibleHint() && !isInit) {
Initialize();
isInit = true;
}
}
/**
* 初始化方法
*/
public abstract void Initialize();
@Override
public void onDestroyView() {
super.onDestroyView();
isCreated = false;
isInit = false;
}
}
复制代码
写完这篇以后对Fragment的生命周期又有了新的认识。好记性不如烂笔头,推荐你们本身也动手去写一写。才能加深印象。
Demo地址:https://github.com/13046434521/LazyFragment
仍是那句老话,风里雨里在这里等你,喜欢的童鞋点个关注呗。你的关注是我最大的动力。毕竟写这个也不容易。若是有哪里不对的请及时指出,但愿你们一块儿进步。
最后来个彩蛋,今天在找生命周期图时在Google文档官网看到的!!!别忘了关注一下,哈哈,感谢