Fragment的生命周期
2016-06-06 15:53
387 查看
Fragment的生命周期 * 1,onAttach() * 这个时候 activity已经传进来了获得activity的传递的值就可以进行 与activity的通信里 * 2,onCreate() * 当你 暂停 停止的时候 你想保持的数据如果我们要为fragment启动一个后台线程,可以考虑将代码放于此处。 * 3,onCreateView() * 加载fragment的布局的,这里一般都先判断是否为null这样进行各判断省得每次都要加载,减少资源消耗, 第一次使用的时候 fragment会在这上面画一个layout出来, * 4,onActivityCreated() * 当Activity中的onCreate方法执行完后调用。 * 5,onStart() 和activity一致 启动, Fragement 启动时回调, 此时Fragement可见; 6,onResume() 和activity一致 在activity中运行是可见的激活, Fragment 进入前台, 可获取焦点时激活; 7,onPause() 和activity一致 其他的activity获得焦点,这个仍然可见 8,onStop() 和activity一致fragment不可见的, 可能情况:activity被stopped了 OR fragment被移除但被加入到回退栈中 一个stopped的fragment仍然是活着的如果长时间不用也会被移除 9,onDestroyView() Fragment中的布局被移除时调用,表示fragemnt销毁相关联的UI布局,清除所有跟视图相关的资源.
<code>相信大家都用过ViewPager+Fragment,由于ViewPager的缓存机制,每次都会加载3页。 例如:有四个 fragment 当滑动到第四页的时候 第一页执行onDestroyView(),但没有执行onDestroy。他依然和activity关联。当在滑动到第一页的时候又执行了 onCreateView()。 生命周期可以自己试一下。 那么问题来了。会出现重复加载view的局面,所以这么做(下面是先人的代码) </code>
<code class=" hljs java" style="display: block; padding: 0.5em; color: rgb(0, 0, 0); background: rgb(255, 255, 255);"><span class="hljs-annotation" style="color: rgb(155, 133, 157);">@Override</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136);">public</span> <span class="hljs-keyword" style="color: rgb(0, 0, 136);">void</span> <span class="hljs-title">onDestroyView</span>() { Log.i(<span class="hljs-string" style="color: rgb(0, 136, 0);">"onDestroyView_Fragment"</span>); <span class="hljs-keyword" style="color: rgb(0, 0, 136);">if</span>(view!=<span class="hljs-keyword" style="color: rgb(0, 0, 136);">null</span>){ ((ViewGroup)view.getParent()).removeView(view); } <span class="hljs-keyword" style="color: rgb(0, 0, 136);">super</span>.onDestroyView(); }</code>onDestroy()<code> 销毁fragment对象
跟activity类似了。
</code>onDetach()<code> Fragment和Activity解除关联的时候调用。
脱离activity
</code>可见fragment的销毁还是很优雅地,一个一个的来。下面贴一下 activity和fragment同时运行时候的 生命周期<code class=" hljs mathematica" style="display: block; padding: 0.5em; color: rgb(0, 0, 0); background: rgb(255, 255, 255);">开始启动:
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): oncreate
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onAttach_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onCreate_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onCreateView_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onActivityCreated_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStart
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStart_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onResume
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">08.553</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onResume_Fragment
按下home按键
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">28.725</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onPause_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">28.725</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onPause
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">29.221</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStop_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">29.221</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStop
再回到界面
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">49.441</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onRestart
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">49.441</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStart
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">49.441</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStart_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">49.441</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onResume
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">55</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">49.441</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onResume_Fragment
销毁activity
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.293</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onPause_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.293</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onPause
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStop_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onStop
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onDestroyView_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onDestroy_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onDetach_Fragment
<span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>-<span class="hljs-number" style="color: rgb(0, 102, 102);">07</span> <span class="hljs-number" style="color: rgb(0, 102, 102);">05</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">59</span>:<span class="hljs-number" style="color: rgb(0, 102, 102);">02.757</span>: <span class="hljs-keyword" style="color: rgb(0, 0, 136);">I</span>/<span class="hljs-keyword" style="color: rgb(0, 0, 136);">Log</span>(<span class="hljs-number" style="color: rgb(0, 102, 102);">1990</span>): onDestroy
</code>可以看出 当现实fragment的时候都先执行activity方法,当销毁的时候都是现执行 fragment的方法,这样更好理解fragment是嵌套在activity中
时间仓促,理解不到位的尽管提出来,向各位大神学
相关文章推荐
- GUI - Web前端开发框架
- 评价ui设计作品好坏的八个标准(界面/交互设计研究)
- Jquery ui datepicker设置日期范围,如只能隔3天【实现代码】
- 为Yahoo! UI Extensions Grid增加内置的可编辑器
- Cocos2d-x UI开发之文本类使用实例
- 谈谈对jquery ui tabs 的理解
- 在IE 浏览器中使用 jquery的fadeIn() 效果 英文字符字体加粗
- UI Events 用户界面事件
- jquery UI Datepicker时间控件的使用方法(基础版)
- Hallo.js基于jQuery UI所见即所得的Web编辑器
- 基于jQuery UI CSS Framework开发Widget的经验
- jquery ui 1.7 ui.tabs 动态添加与关闭(按钮关闭+双击关闭)
- jquery UI Datepicker时间控件的使用及问题解决
- jQuery UI设置固定日期选择特效代码分享
- Jquery ajax 同步阻塞引起的UI线程阻塞问题
- jQuery UI的Dialog无法提交问题的解决方法
- jQuery ui实现动感的圆角渐变网站导航菜单效果代码
- jquery UI Datepicker时间控件的使用方法(终结版)
- jquery UI Datepicker时间控件的使用方法(加强版)
- 关于jQuery UI 使用心得及技巧