引言:
在实际开发中,Fragment使用经常会结合viewpager一起使用,页面可能会由三个或更多Fragment构成,ViewPager有个预加载机制,加载的时候默认会把当前可见的Fragment俩边的Fragment同时加载进来,只有所有界面都加载完毕,当前可见的Fragment才会显示。这样子就会引发一个问题:如下图当我启动app的时候当前可见的Fragment是首页,但是ViewPager预加载机制也会加载小视频Fragment,但是我在小视频这个fragment生命周期中进行了几秒的耗时操作,这就会导致我进入首页的时候很慢,因为app要等首页和小视频这俩个fragment同时加载完毕才会显示。
上图只是我为了测试手动打的一个Thread.sleep();
但是日常我们所使用的app肯定会有一些网络请求操作,这些是比较耗时的,如果处理不好很影响用户体验。所于出现了fragment懒加载这个概念,对于懒加载,通俗点讲就是看不见的先不加载,当需要时再进行加载,让体验(页面绘制)、流量等更节省。就好比下图我只加载首页,小视频的我先不加载,你点开了我在加载,这样子进入首页很快。
在上代码之前我们先解释一个方法:
setUserVisibleHint(boolean b)
这个方法在Fragment的生命周期里oncreate()方法之前会调用,作用是设置Fragment是否可见,切换Fragment的时候也会调用,通过getUserVisibleHint()返回的值我们可以知道Fragment是否可见。
实现懒加载思路:
在BaseFragment里设置三个标识:
isFragmentVisible :Fragme