Fragment与Fragment相互切换之间的生命周期方法
Fragment 1 切换到 Fragment 2时生命周期变化
1、通过 add hide show 方式来切换 Fragment
-
Fragment1 的生命周期变化为:onCreate()、onCreateView、onStart()、onResume()
回调 onHiddenChanged() 方法
-
Fragment2 的生命周期变化为: onCreate()、onCreateView、onStart()、onResume()
-
Fragment 2 再次返回到 Fragment 1:不走任何生命周期方法但是回调 onHiddenChanged()方法
总结:当以这种方式进行 Fragment 1 与 Fragment 2 的切换时,Fragment 隐藏的时候并不走 onDestroyView,所有的显示也不会走 onCreateView 方法,所有的 view 都会保存在内存
2、使用 replace 的方法进行切换时
- 载入Fragment 1时:
Fragment 1的生命周期:onCreate()、onCreateView()、onStart()、onResume()
- 切换到Fragment2时:
Fragment 1的生命周期:onPause()、onStop()、onDestroyView()、onDestroy()
Fragment 2的生命周期:onCreate()、onCreateV()、onStart()、onResume()
- Fragment 2切换回Fragment 1时:
Fragment2的生命周期:onPause()、onStop()、onDestroyView()、onDestroy()
Fragment 1的生命周期:onCreate()、onCreateV()、onStart()、onResume()
总结:通过 replace 方法进行替换的时,Fragment 都是进行了销毁,重建的过程,相当于走了一整套的生命周期
3、使用 ViewPager 进行切换时
当使用 ViewPager 与 Fragment 进行切换时,Fragment 会进行预加载操作
所有的 Fragment 都会提前初始--->预加载;
初始化时 Fragment 们的生命周期:
Fragment 1 的生命周期:onCreate()、onCreateView()
Fragment 2 的生命周期:onCreate()、 onCreateView()
Fragment 1 切换到 Fragment 2 的生命周期:
Fragment 1 :不走任何生命周期;
Fragment 2 :走 setUserVisVleHint()方法
切回去也是一样的
注意: setUserVisVleHint()方法在 Fragment 1 第一次加载的时候不走,只有在切换的时候 走该方法
具体加载数据的代码
/** * 判断是否是初始化Fragment */ private boolean mIsHasStarted = false; /** * 本方法会在ViewPager + Fragment结合时会执行 * 初始化时会执行两次,一次在 onCreate 之前 isVisibleToUser 为false, * 另一次在 onCreate 之后 isVisibleToUser 为true * @param isVisibleToUser */ @Override public void setUserVisibleHint(boolean isVisibleToUser) { super.setUserVisibleHint(isVisibleToUser); if (isVisibleToUser) { setHotUnClick(DELAY_WHEN_APPEAR); mIsHasStarted = true; Logcat.i(TAG, "Start interface 开始界面"); } else { if (mIsHasStarted) { mIsHasStarted = false; Logcat.i(TAG, "End interface 结束界面"); } } }
Activity 切换到 Fragment 的生命周期变化
Fragment 的生命周期变化为:onStart()、onResume()
从 Fragment 1 进行锁屏操作
Fragment 的生命周期方法:onPause()、onSaveInstanceState()、onStop()。
从解锁 到 Fragment 1 的生命周期
onStart()、 onResume()
链接:https://www.jianshu.com/p/c8f34229b6dc
上一篇: 函数-生成器、迭代器
下一篇: js数组详解