Fragment的定义
Fragment被称为第五大组件,有自己的生命周期,可以像Activity那样进行灵活处理。起初是为了给大屏幕UI展示进行的灵活处理。Fragment不是独立的,必须依附(attach)并加载到Activity才能使用,
Fragment的生命周期
结合Activity的生命周期来分析:
1、Fragment从启动到展现的生命周期:
onAttach():表示Fragment与Activity建立关联(Fragment被添加到Activity时调用)
onCreate():初次创建Fragment(此时并没有创建完成)
onCreateView():Fragment首次绘制用户界面,由于是绘制Fragment的UI,所以此方法中返回的View必须是Fragment布局的根视图
onViewCreated():Fragment的创建与视图绘制完成(在此方法可以初始化Fragment的控件资源)
Activity-onCreate():初始化Activity
onActivityCreated():Activity被渲染绘制成功后调用
Activity-onStart():表明Activity可见了
onStart():表明Fragment可见了
Activity-onResume():整个Activity与用户可以进行交互了
onResume():整个Fragment与用户可以进行交互了;(可以进行滑动、点击等操作)2、Fragment销毁的生命周期
onPause():表示Fragment停止与用户的交互
Activity-onPause():表示Activity停止与用户的交互
onStop():在onPause()之后调用
Activity-onStop()
onDestroyView():销毁Fragment的View组件时回调
onDestroy():销毁Fragment时调用(只调用一次)
onDetach():将Fragment从Activity中删除、被替换完成时回到该方法,在onDestroy()之后回调
Activity-onDestroy()
Fragment的优点
1、响应速度快:Activity也能进行业务逻辑的分割或者场景的转换,但是Fragment比Activity占用少得多的系统资源,特别是在中低端手机上,Fragment的响应速度相较于Activity成倍的提高。
2、灵活性强:因为Fragment是一个个的碎片,所以我们更容易控制每个场景的生命周期和状态,比 Activity的灵活性大了很多。
3、移植性好:当我们的App想要移植到平板上时,Fragment会大大减少我们的开发量。
Fragment加载到Activity的两种方式
1、静态加载,直接把Fragment组件添加到xml布局文件中。
2、动态加载,通过FragmentManager来管理Fragment,并创建FragmentTransaction实例,调用FragmentTransaction中的add()方法进行添加,最后调用FragmentTransaction中的commit()方法来完成动态加载Fragment的操作。
FragmentPagerAdapter与FragmentStatePagerAdapter的区别
FragmentPagerAdapter适用于界面较少的情况,而FragmentStatePagerAdapter适用于界面较多的情况。原因通过源码来分析:关键在于内存的消耗问题,FragmentStatePagerAdapter的销毁方法destroyItem()最终调用的是remove()方法,即真正释放了Fragment的内存;FragmentPagerAdapter的销毁方法destroyItem()最终调用的是detach()方法,这个方法并不是真正的内存回收,而是把Fragment的UI和Activity的UI脱离开来,而不是回收内存。所以FragmentStatePagerAdapter在每次页面切换时是回收内存的,所以适用于界面比较多的情况;FragmentPagerAdapter在每次页面切换时是不回收内存的,所以适用于界面比较少的情况。
FragmentPagerAdapter执行的销毁:onDestroyView()
Fragment重新创建:onCreateView() -> onActivityCreated() -> onStart() -> onResume()FragmentStatePagerAdapter执行的销毁: onDestroyView() -> onDestroy() -> onDetach()
Fragment重新创建:onAttach() -> onCreate() -> onCreateView() -> onActivityCreated() -> onStart() -> onResume()
Fragment的通信
1、在Fragment中如何获得Activity:直接调用getActivity()
2、在Activity中如何获得Fragment:接口回调
3、在Fragment如何获得Fragment:findFragmentById()
Fragment的回退栈
主要是通过FragmentManager开启FragmentTransaction事务,然后调用addToBackStack()方法,最后通过commit()方法提交事务,此时当前Fragment就被加入了回退栈中。
比如FragmentA跳转到FragmentB,然后按Back键返回,如果没有加入回退栈的话,不会返回FragmentA页面,而是直接退出,具体什么生命周期如下:
FragmentA跳转到FragmentB:
FragmentA:onPause() -> onStop() -> onDestroyView() -> onDestroy() -> onDetach()
FragmentB:onAttach() -> onCreate() -> onCreateView() -> onActivityCreated() -> onStart() -> onResume()FragmentA跳转到FragmentB(FragmentA加入了回退栈):
FragmentA:onPause() -> onStop() -> onDestroyView()
FragmentB:onAttach() -> onCreate() -> onCreateView() -> onActivityCreated() -> onStart() -> onResume()FragmentB通过Back键返回(FragmentA加入了回退栈):
FragmentB:onPause() -> onStop() -> onDestroyView() -> onDestroy() -> onDetach()
FragmentA:onCreateView() -> onActivityCreated() -> onStart() -> onResume()