返回顶部
首页 > 资讯 > 移动开发 >AndroidFragment源码分析Add方法
  • 553
分享到

AndroidFragment源码分析Add方法

AndroidFragmentAdd方法AndroidFragment源码分析 2022-11-13 14:11:34 553人浏览 泡泡鱼
摘要

目录前言Add()前言 本篇我们就来讲讲Fragment管理中的 Add() 方法 Add() 在我们动态的添加、管理Fragment中,Add属于最基础的方法了; 用法也很简单,如

前言

本篇我们就来讲讲Fragment管理中的 Add() 方法

Add()

在我们动态的添加、管理Fragment中,Add属于最基础的方法了; 用法也很简单,如下就是向Activity添加一个Fragment:

getSupportFragmentManager().beginTransaction().add(R.id.fragmenta,new FragmentA()).commit();

一般时候我们使用到Fragment的时候,都是不止一个,比如微信界面,底部导航有四个按钮,分别对应不同的四个Fragment,像这种的每点击一次底部按钮就切换一下界面的话,我们就可以使用Add()外加hide和show进行组合

下面我们简单实现一下,这里我们就弄两个Fragment,

这里我们的MainActivity的布局如下:

<LinearLayout xmlns:Android="Http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/activity_main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.shaoen.lenovo.myapplication.MainActivity">
    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:id="@+id/fragmenta"/>
    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <Button
            android:id="@+id/fragmenta_button" 
            android:text="FragmentA"
            android:layout_width="0dp"
            android:layout_height="match_parent" 
            android:layout_weight="1"/>
        <Button
            android:id="@+id/fragmentb_button"
            android:text="FragmentB"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"/>
    </LinearLayout>
</LinearLayout>

下面看MainActivity的内容:

package com.shaoen.lenovo.myapplication;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import com.shaoen.lenovo.myapplication.fragment.FragmentA;
import com.shaoen.lenovo.myapplication.fragment.FragmentB;
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private String  TAG=MainActivity.class.getSimpleName();
    private Button fragmentA_Button;
    private Button fragmentB_Button;
private FragmentTransaction transaction;
    private FragmentManager fragmentManager;
    private Fragment fragment;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Log.i(TAG,"onCreate--执行了");
        setContentView(R.layout.activity_main);
        fragmentManager=getSupportFragmentManager();
        transaction=  fragmentManager.beginTransaction();
        fragment=new FragmentA();
        transaction.add(R.id.fragmenta,fragment,"FragmentA").commit();
        fragmentA_Button=(Button) findViewById(R.id.fragmenta_button);
        fragmentB_Button=(Button) findViewById(R.id.fragmentb_button);
        fragmentA_Button.setOnClickListener(this);
        fragmentB_Button.setOnClickListener(this);
    }
    @Override
    protected void onStart() {
        super.onStart();
        Log.i(TAG,"onStart--执行了");
    }
    @Override
    protected void onResume() {
        super.onResume();
        Log.i(TAG,"onResume--执行了");
    }
    @Override
    protected void onPause() {
        super.onPause();
        Log.i(TAG,"onPause--执行了");
    }
    @Override
    protected void onStop() {
        super.onStop();
        Log.i(TAG,"onStop--执行了");
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
        Log.i(TAG,"onDestroy--执行了");
    }
    @Override
    public void onClick(View v) {
        transaction=  fragmentManager.beginTransaction();
        switch (v.getId()){
            case R.id.fragmenta_button:
                if (fragment!=null)
                    transaction.hide(fragment);
                fragment=  fragmentManager.findFragmentByTag("FragmentA");
                if (fragment!=null){
                    transaction.show(fragment);
                }
                else {
                    fragment=new FragmentA();
                    transaction.add(R.id.fragmenta,fragment,"FragmentA").commit();
                }
                break;
           case R.id.fragmentb_button:
                if (fragment!=null)
                    transaction.hide(fragment);
            fragment=  fragmentManager.findFragmentByTag("FragmentB");
                if (fragment!=null){
                    transaction.show(fragment);
                }
                else {
                    fragment=new FragmentB();
                    transaction.add(R.id.fragmenta,fragment,"FragmentB").commit();
                }
                break;
        }
    }
}

这里我们写的比较简单,主要是为了看一下他们的执行生命周期,在这里我把所以log都打印出来了

刚开始运行时的log如下:

I/MainActivity: onCreate--执行了
I/FragmentA: onAttach--执行了
I/FragmentA: onCreate--执行了
I/FragmentA: onCreateView--执行了
I/FragmentA: onActivityCreated--执行了
I/FragmentA: onStart--执行了
I/MainActivity: onStart--执行了
I/MainActivity: onResume--执行了
I/FragmentA: onResume--执行了

此时我们点击FragmentB按钮;

I/FragmentB: onAttach--执行了
I/FragmentB: onCreate--执行了
I/FragmentB: onCreateView--执行了
I/FragmentB: onActivityCreated--执行了
I/FragmentB: onStart--执行了
I/FragmentB: onResume--执行了

然后我们在反复点击FragmentA和FragmentB按钮,发现没有任何log打印,此时证明FragmentA和FragmentB通过hide和show方法进行切换时,都只会初始化一次,

下面我们看向replace这个方法

replace:

首先replace方法,其实是remove和add方法的组合; remove就是将一个Fragment从FragmentManager中删除,如果我们切换下一个Fragment时,上一个Fragment不需要了,可以直接使用replace,如果我们还需要的话,api中也提供了相应的方法,那就是加入回退栈addToBackStack()

下面我们把MainActivity中的代码改一下:

  @Override
    public void onClick(View v) {
        transaction=  fragmentManager.beginTransaction();
        switch (v.getId()){
            case R.id.fragmenta_button:
                if (fragment!=null)
                    transaction.hide(fragment);
                fragment=  fragmentManager.findFragmentByTag("FragmentA");
                if (fragment!=null){ Log.i(TAG,"fragment不为空");
                    transaction.show(fragment);
                }
                else {
                    Log.i(TAG,"fragment为空");
                    fragment=new FragmentA();
                    transaction.replace(R.id.fragmenta,fragment,"FragmentA").addToBackStack("FragmentA").commit();
                }
                break;
           case R.id.fragmentb_button:
                if (fragment!=null)
                    transaction.hide(fragment);
            fragment=  fragmentManager.findFragmentByTag("FragmentB");
                if (fragment!=null){
                    Log.i(TAG,"fragment不为空");
                    transaction.show(fragment);
                }
                else {
                    Log.i(TAG,"fragment为空");
                    fragment=new FragmentB();
                    transaction.replace(R.id.fragmenta,fragment,"FragmentB").addToBackStack("FragmentB").commit();
                }
                break;
        }
        }

这里我们就改了一下OnClick中的代码,这时我们再打印一下log看看:

首先初始化时是一致的:

这里写代码片

此时我们点击FragmentB:

12-18 21:48:14.227 21081-21081/com.shaoen.lenovo.myapplication I/MainActivity: fragment为空
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onPause--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStop--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onDestroyView--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onAttach--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreate--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreateView--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onActivityCreated--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStart--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onResume--执行了

我们发现Fragment调用了destroy方法,此时我们再点击FragmentA:

I/MainActivity: fragment不为空

此时发现FragmentA没有切换过来,这是因为,我们在FragmentManager中找到了FragmentA的实例,但是此时,FragmentA的界面已经被销毁了,所以我们看见的还是FragmentB,此时我们的OnClick改成如下:

   @Override
    public void onClick(View v) {
        transaction=  fragmentManager.beginTransaction();
        switch (v.getId()){
            case R.id.fragmenta_button:
                    fragment=new FragmentA();
                    transaction.replace(R.id.fragmenta,fragment,"FragmentA").addToBackStack("FragmentA").commit();
                break;
           case R.id.fragmentb_button:
                    fragment=new FragmentB();
                    transaction.replace(R.id.fragmenta,fragment,"FragmentB").addToBackStack("FragmentB").commit();
                break;
        }
    }

这时再打印一下log,

12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onPause--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStop--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onDestroyView--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onAttach--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreate--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreateView--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onActivityCreated--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStart--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onResume--执行了

12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onPause--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStop--执行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onDestroyView--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onAttach--执行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onCreate--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onCreateView--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onActivityCreated--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStart--执行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onResume--执行了

此时发现每次切换时,都会调用Fragment都会重新调用onCreateView()到onDestroyView()的所有方法,其实就是Fragment的布局层整个销毁到重建的过程

注: 当我们进行Fragment嵌套时,如果我们点击返回键,不想回到上一个Fragment,而想直接回到更往前一个,或者更往前的Fragment,我们可以使用FragmentManager.popBackStackImmediate (String tag, int flags)方法,弹出TAG为tag的Fragment,同时把此Fragment以上的Fragment全都弹出(弹出回退栈,即彻底销毁,detach)

到此这篇关于Android Fragment源码分析Add方法的文章就介绍到这了,更多相关Android Fragment内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: AndroidFragment源码分析Add方法

本文链接: https://lsjlt.com/news/172370.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • AndroidFragment源码分析Add方法
    目录前言Add()前言 本篇我们就来讲讲Fragment管理中的 Add() 方法 Add() 在我们动态的添加、管理Fragment中,Add属于最基础的方法了; 用法也很简单,如...
    99+
    2022-11-13
    Android Fragment Add方法 Android Fragment 源码分析
  • thinkphp中add方法实例分析
    这篇文章主要介绍了thinkphp中add方法实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇thinkphp中add方法实例分析文章都会有所收获,下面我们一起来看看吧。thinkphp中add()方法的...
    99+
    2023-06-29
  • vue3新方法源码分析
    这篇文章主要讲解了“vue3新方法源码分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue3新方法源码分析”吧!创建应用程序在 Vue 3 中,创建应用程序的方式有所改变。传统上,我们使...
    99+
    2023-07-06
  • 解析ConcurrentHashMap: put方法源码分析
    上一章:预热(内部一些小方法分析) put()方法是并发HashMap源码分析的重点方法,这里涉及到并发扩容,桶位寻址等等… JDK1.8 ConcurrentHa...
    99+
    2024-04-02
  • 解析ConcurrentHashMap: transfer方法源码分析(难点)
    上一篇文章介绍过put方法以及其相关的方法,接下来,本篇就介绍一下transfer这个方法(比较难),最好能动手结合着源码进行分析,并仔细理解前面几篇文章的内容~ ...
    99+
    2024-04-02
  • python实例方法、静态方法与类方法源码分析
    本篇内容介绍了“python实例方法、静态方法与类方法源码分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • laravel源码分析队列Queue方法示例
    目录前言队列任务的创建队列任务的分发前言 队列 (Queue) 是 laravel 中比较常用的一个功能,队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短 Web 请求...
    99+
    2024-04-02
  • Vue3源码分析reactivity实现方法示例
    目录深入分析对于map、set、weakMap、weakSet的响应式拦截(1).mutableInstrumentations(2).shallowInstrumentations...
    99+
    2023-01-28
    Vue3源码分析reactivit方法 Vue reactivit
  • laravel源码分析队列Queue方法怎么用
    本篇内容介绍了“laravel源码分析队列Queue方法怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!队列任务的创建先通过命令创建一个...
    99+
    2023-06-29
  • 【Queue】- 从源码分析PriorityQueue及其常用方法
    文章目录 PriorityQueue基础知识 概述 PriorityQueue内部结构 PriorityQueue扩容操作 PriorityQueue队列的构造方法 PriorityQue...
    99+
    2023-08-17
    java 源码 优先级队列 PriorityQueue Queue
  • RateLimiter 源码分析
    俗话说得好,缓存,限流和降级是系统的三把利剑。刚好项目中每天早上导出数据时因调订单接口频率过高,订单系统担心会对用户侧的使用造成影响,让我们对调用限速一下,所以就正好用上了。 常用的限流算法有2种:漏桶算法和令牌桶算法。漏桶算法漏...
    99+
    2023-05-31
    ratelimiter 源码 mi
  • SocketServer 源码分析
    Creating network servers. contents SocketServer.py contents file head BaseServer BaseServer.serve_forever BaseServ...
    99+
    2023-01-31
    源码 SocketServer
  • CesiumJS源码分析
    这篇文章主要介绍“CesiumJS源码分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CesiumJS源码分析”文章能帮助大家解决问题。1. 有什么光CesiumJS 支持的光的类型比较少,默认场...
    99+
    2023-07-06
  • Spring invokeBeanFactoryPostProcessors方法刨析源码
    概述 invokeBeanFactoryPostProcessor方法是spring核心方法之一,主要用来调用beanFactory后置处理器来修改beanDefinition。 该...
    99+
    2023-01-13
    Spring invokeBeanFactoryPostProcessors Spring invokeBeanFactoryPostProcessors方法
  • Netty分布式flush方法刷新buffer队列源码分析
    本文小编为大家详细介绍“Netty分布式flush方法刷新buffer队列源码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“Netty分布式flush方法刷新buffer队列源码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-06-29
  • Java Zookeeper分布式分片算法源码分析
    这篇文章主要介绍了Java Zookeeper分布式分片算法源码分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java Zookeeper分布式分片算法源码分析文章都会有所收获,下面我们...
    99+
    2023-07-05
  • Java源码角度分析HashMap用法
    —HashMap—优点:超级快速的查询速度,时间复杂度可以达到O(1)的数据结构非HashMap莫属。动态的可变长存储数据(相对于数组而言)。缺点:需要额外计算一次hash值,如果处理不当会占用额外的空间。—HashMap如何使用—平时我们...
    99+
    2023-05-30
  • Kafka源码分析(一)
    Apache Kafka® 是 一个分布式流处理平台. 这到底意味着什么呢 我们知道流处理平台有以下三种特性: 可以让你发布和订阅流式的记录。这一方面与消息队列或者企业消息系统类似。 可以储存流式的记录,并且有较好的容错性。 可...
    99+
    2019-10-17
    Kafka源码分析(一)
  • Android LayoutInflater.inflate源码分析
    LayoutInflater.inflate源码详解 LayoutInflater的inflate方法相信大家都不陌生,在Fragment的onCreateView中或者在Ba...
    99+
    2022-06-06
    layoutinflater Android
  • Android AsyncTask源码分析
    Android中只能在主线程中进行UI操作,如果是其它子线程,需要借助异步消息处理机制Handler。除此之外,还有个非常方便的AsyncTask类,这个类内部封装了Handl...
    99+
    2022-06-06
    asynctask Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作