Fragment切换以及懒加载

hide show add replace

 `add`与`replace`在添加一个新的`Fragment`时没有什么区别,生命周期调用完全相同
image.png

不同点:

  • add只能添加一次,多次添加会有Fragment already added错误抛出,
  • replace则没有这个限制,如果当前显示的Fragment和要replaceFragment相同,则不会再次触发Fragment的生命周期

replace

使用replace每次调用,除了与当前Fragment相同的情况下,会销毁当前的Fragment,然后创建添加一个新的Fragment,生命周期如下:

image.png

show 与 hide

show与hide只是简单显示和隐藏操作,对Fragment的生命周期以及状态不会有任何的影响,当然show与hide之前,要确认已经添加到FragmentManager中了

if (mFragment1.isAdded()) {
    mManager.beginTransaction().hide(mCurFragment).show(mFragment1).commit();
 } else {
    mManager.beginTransaction().hide(mCurFragment).add(R.id.frameLayout, mFragment1).commit();
 }

Fragment懒加载

我们经常需要用到底部导航栏加Fragment配合形成主页面框架,多数时候还会配合ViewPager,那么分两种情况

  • 不使用ViewPager
    通过上面对show,hide等的了解,我们可以让FragmentManager直接维护n(当然n代表的是少数,一般首页都在5个以内)个FragmentActivity创建的时候直接初始化所有Fragment,但是没有数据请求等逻辑处理,只做页面初始化,然后使用show,hide方式来处理调用显示某一个Fragment,因为切换的时候不会调用生命周期,所以不可能通过生命周期来处理内部逻辑,我们可以在Fragment中定义一些public 方法,处理数据请求等逻辑,例如,这个是定义在Fragment中的方法,供Activity调用
/**
     * 设置选中状态,可以自己增加一些参数,比如是否需要刷新页面等等
     * @param checked 当前是否选中
     */
    public void checked(boolean checked) {
        if (checked) {
            //显示在界面上
            //可以处理相关逻辑
            if (this.hasLoadedData) {
                //是否已经加载过数据
            } else {
                
            }
        } else {
            //隐藏
            //可能需要处理一些暂停任务,比如banner轮询等等
        }
    }

这样在切换Fragment时,就可以避免使用replace来回产生的销毁与创建,导致数据的反复加载,可以很好的提升体验

当然上面已经说过,这只适合个数比较少的Fragment,如果较多的情况下,不释放,反而导致内存一直居高不下

  • 使用ViewPager
    使用ViewPager的时候增加了一个在api 16增加了一个新的方法
@Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
    }

isVisibleToUser就是标示是否为ViewVager当前选中的item,我们可以从此着手来实现

我们都知道

mViewPager.setOffscreenPageLimit(n);

可以用来设置两侧保留几个不被销毁的Fragment,比如当前有4个选项卡,那么我们设置n = 3,这样Fragment就不会被销毁,类似上面不使用ViewPager的情况下的checked(boolen checked)方法

@Override
    public void setUserVisibleHint(boolean isVisibleToUser) {
        super.setUserVisibleHint(isVisibleToUser);
        if (isVisibleToUser) {
            //显示在界面上
            //可以处理相关逻辑
            if (this.hasLoadedData) {
                //是否已经加载过数据
            } else {

            }
        } else {
            //隐藏
            //可能需要处理一些暂停任务,比如banner轮询等等
        }
    }

首次加载页面Fragment生命周期的调用

image.png
image.png

切换tab


image.png
image.png

由于Demo比较简陋,就不上传源码了

你可能感兴趣的:(Fragment切换以及懒加载)