前言
我又来了,哈哈。因为项目中用到了懒加载,之前也用过一次,但是原理没有弄懂只记的大概。
所以特意写了篇文章,希望可以加深印象,要是能够帮助不是很了解的小伙伴那就更好了。废话不多少了,进入正题。
什么是懒加载
image.png我们在做项目的时候经常会用到ViewPager+TabLayout作为页面切换。而切换的内容就是Fragment。可是有一个问题就是ViewPager为了节省用户等待时间,默认的会预加载左右各一个页面(可以根据 viewPager.setOffscreenPageLimit(limit)来设定)。
当我打开为Page1的时候,其实Page0,和Page2。已经生成,并且会执行onAttach->->->onResume期间的方法。如果有大量的操作的话,可能会导致卡顿。因此,有的人会想当我滑动到哪个页面的时候,在执行我想要的网络请求操作。所以才会有了懒加载!
生命周期
Fragment生命周期要搞懂懒加载,就要弄清楚Fragment的生命周期。这里为了方便大家观察我在这里传入一张Fragment的生命周期图。
实例
3.gif这里我写了个Demo,为了更加方便大家观察。如图:
1.当我们加载Page0的时候:
setUserVisibleHint第一个执行的不是我们熟知的onAttach方法。而是setUserVisibleHint方法。这个方法就是懒加载的关键。在使用ViewPager生成Fragment的时候会预先调用这个方法,告诉用户该界面是否可见。之后才会正常执行到onResume生命周期。因为我们预加载了page1页面,所以page1页面也执行到了onResume方法。
2.当滑动到Page1的时候
Page1已经预加载完毕。执行Page1的setUserVisibleHint方法,并且visible为true即可见
Page0隐藏。执行Page0的setUserVisibleHint方法,并且visible为false即不可见
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文档官网看到的
网友评论