zoukankan      html  css  js  c++  java
  • 常见场景下Fragment和Activity的生命周期对比

    Activity 生命周期图

    img

    Fragment生命周期图

    这张广为流传的图,并没有标注Framgnet生命周期没有onViewCreated这一项生命周期。

    但是经测试发现,Fragment启动的生命周期的执行流程为:
    onAttach->onCreate->onCreateView->onViewCreated->onActivityCreated->onStart

    常见场景下Fragment和Activity的生命周期

    • 初次进入Activity时,Fragment1也会显示:
    1. 先执行MyActivity的 onCreate方法,再执行Fragment1的onAttach、onAttach、onCreateView、onActivityCreated方法。
    2. MyActivity、Fragment1的 onStart --> MyActivity、Fragment1的 onResume方法。
    3. 可见在首次进入Activity时,Activity要优先Fragment一步
        E/MyActivity: onCreate:  <————MyActivity
        E/Fragment1: onAttach:  <————Fragment1
        E/Fragment1: onCreate:  <————Fragment1
        E/Fragment1: onCreateView: <————Fragment1 
        E/Fragment1: onActivityCreated: <————Fragment1 
        E/MyActivity: onStart:  <————MyActivity
        E/Fragment1: onStart:  <————Fragment1
        E/MyActivity: onResume:  <————MyActivity
        E/Fragment1: onResume: <————Fragment1 
    
    • 将屏幕关闭时

      Fragment1,MyActivity分别执行onPause、onStop方法。 可见在暂停时Fragment要优先Activity一步

           E/Fragment1: onPause: <————Fragment1
           E/MyActivity: onPause:  <————MyActivity
           E/Fragment1: onStop:  <————Fragment1
           E/MyActivity: onStop:  <————MyActivity
    
    • 将屏幕重新打开时

      会执行:

      ​ MyActivity的onRestart ->>

      ​ MyActivity、Fragment1的onStart ->>

      ​ MyActivity、Fragment1的onResume,

      Activity要优先Fragment一步

           E/MyActivity: onRestart:  <————MyActivity
           E/MyActivity: onStart:  <————MyActivity
           E/Fragment1: onStart:  <————Fragment1
           E/MyActivity: onResume:  <————MyActivity
           E/Fragment1: onResume: <————Fragment1
    
    • 由Fragment1跳转到Fragment2时
            E/Fragment1: onPause: <————Fragment1 
            E/Fragment1: onStop:  <————Fragment1
            E/Fragment1: onDestroyView:  <————Fragment1
            E/Fragment1: onDestroy: <————Fragment1 
            E/Fragment1: onDetach: <————Fragment1 
            E/Fragment2: onAttach:  <————Fragment2
            E/Fragment2: onCreate:  <————Fragment2
            E/Fragment2: onCreateView: <————Fragment2 
            E/Fragment2: onActivityCreated: <————Fragment2 
            E/Fragment2: onStart:  <————Fragment2
            E/Fragment2: onResume: <————Fragment2 
    
    • 由Fragment2返回到Fragment1时
            E/Fragment2: onPause: <————Fragment2 
            E/Fragment2: onStop:  <————Fragment2
            E/Fragment2: onDestroyView:  <————Fragment2
            E/Fragment2: onDestroy: <————Fragment2 
            E/Fragment2: onDetach: <————Fragment2 
            E/Fragment1: onAttach:  <————Fragment1
            E/Fragment1: onCreate:  <————Fragment1
            E/Fragment1: onCreateView: <————Fragment1 
            E/Fragment1: onActivityCreated: <————Fragment1 
            E/Fragment1: onStart:  <————Fragment1
            E/Fragment1: onResume: <————Fragment1 
    
    • 退出MyActivity时
        E/Fragment1: onPause: <————Fragment1 
        E/MyActivity: onPause:  <————MyActivity
        E/Fragment1: onStop:  <————Fragment1
        E/MyActivity: onStop:  <————MyActivity
        E/Fragment1: onDestroyView:  <————Fragment1
        E/Fragment1: onDestroy: <————Fragment1 
        E/Fragment1: onDetach: <————Fragment1 
        E/MyActivity: onDestroy:  <————MyActivity
    

    有待以后继续补充

  • 相关阅读:
    CSS3-文本渐变色
    doT.js-doT模板方便快捷的组织页面DOM
    js库-AngularJS
    js-点击按钮页面滚动到顶部,底部,指定位置
    js-页面进入时同时实现-图片预加载
    js-jquery 中$.ajax -浅显接触
    js-数字渐增到指定的数字,在指定的时间内完成(有动画效果哦)插件jquery.animateNumber.js
    小程序-生成一个小程序码画在canvas画布上生成一张图片分享出去
    小程序-点击按钮回到顶部1
    vivo手机的坑-禁止微信浏览器网页点击图片,图片会自动放大
  • 原文地址:https://www.cnblogs.com/DMingO/p/13199105.html
Copyright © 2011-2022 走看看