網(wǎng)站首頁 編程語言 正文
前言
本篇我們就來講講Fragment管理中的 Add() 方法
Add()
在我們動態(tài)的添加、管理Fragment中,Add屬于最基礎(chǔ)的方法了; 用法也很簡單,如下就是向Activity添加一個Fragment:
getSupportFragmentManager().beginTransaction().add(R.id.fragmenta,new FragmentA()).commit();
一般時候我們使用到Fragment的時候,都是不止一個,比如微信界面,底部導航有四個按鈕,分別對應(yīng)不同的四個Fragment,像這種的每點擊一次底部按鈕就切換一下界面的話,我們就可以使用Add()外加hide和show進行組合
下面我們簡單實現(xiàn)一下,這里我們就弄兩個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的內(nèi)容:
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--執(zhí)行了");
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--執(zhí)行了");
}
@Override
protected void onResume() {
super.onResume();
Log.i(TAG,"onResume--執(zhí)行了");
}
@Override
protected void onPause() {
super.onPause();
Log.i(TAG,"onPause--執(zhí)行了");
}
@Override
protected void onStop() {
super.onStop();
Log.i(TAG,"onStop--執(zhí)行了");
}
@Override
protected void onDestroy() {
super.onDestroy();
Log.i(TAG,"onDestroy--執(zhí)行了");
}
@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;
}
}
}
這里我們寫的比較簡單,主要是為了看一下他們的執(zhí)行生命周期,在這里我把所以log都打印出來了
剛開始運行時的log如下:
I/MainActivity: onCreate--執(zhí)行了
I/FragmentA: onAttach--執(zhí)行了
I/FragmentA: onCreate--執(zhí)行了
I/FragmentA: onCreateView--執(zhí)行了
I/FragmentA: onActivityCreated--執(zhí)行了
I/FragmentA: onStart--執(zhí)行了
I/MainActivity: onStart--執(zhí)行了
I/MainActivity: onResume--執(zhí)行了
I/FragmentA: onResume--執(zhí)行了
此時我們點擊FragmentB按鈕;
I/FragmentB: onAttach--執(zhí)行了
I/FragmentB: onCreate--執(zhí)行了
I/FragmentB: onCreateView--執(zhí)行了
I/FragmentB: onActivityCreated--執(zhí)行了
I/FragmentB: onStart--執(zhí)行了
I/FragmentB: onResume--執(zhí)行了
然后我們在反復點擊FragmentA和FragmentB按鈕,發(fā)現(xiàn)沒有任何log打印,此時證明FragmentA和FragmentB通過hide和show方法進行切換時,都只會初始化一次,
下面我們看向replace這個方法
replace:
首先replace方法,其實是remove和add方法的組合; remove就是將一個Fragment從FragmentManager中刪除,如果我們切換下一個Fragment時,上一個Fragment不需要了,可以直接使用replace,如果我們還需要的話,API中也提供了相應(yīng)的方法,那就是加入回退棧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--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStop--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onDestroyView--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onAttach--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreate--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreateView--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onActivityCreated--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStart--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onResume--執(zhí)行了
我們發(fā)現(xiàn)Fragment調(diào)用了destroy方法,此時我們再點擊FragmentA:
I/MainActivity: fragment不為空
此時發(fā)現(xiàn)FragmentA沒有切換過來,這是因為,我們在FragmentManager中找到了FragmentA的實例,但是此時,F(xiàn)ragmentA的界面已經(jīng)被銷毀了,所以我們看見的還是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--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStop--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onDestroyView--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onAttach--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreate--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onCreateView--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onActivityCreated--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStart--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onResume--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onPause--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onStop--執(zhí)行了
12-18 21:48:14.228 21081-21081/com.shaoen.lenovo.myapplication I/FragmentB: onDestroyView--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onAttach--執(zhí)行了
12-18 21:48:14.229 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onCreate--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onCreateView--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onActivityCreated--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onStart--執(zhí)行了
12-18 21:48:14.250 21081-21081/com.shaoen.lenovo.myapplication I/FragmentA: onResume--執(zhí)行了
此時發(fā)現(xiàn)每次切換時,都會調(diào)用Fragment都會重新調(diào)用onCreateView()到onDestroyView()的所有方法,其實就是Fragment的布局層整個銷毀到重建的過程
注: 當我們進行Fragment嵌套時,如果我們點擊返回鍵,不想回到上一個Fragment,而想直接回到更往前一個,或者更往前的Fragment,我們可以使用FragmentManager.popBackStackImmediate (String tag, int flags)方法,彈出TAG為tag的Fragment,同時把此Fragment以上的Fragment全都彈出(彈出回退棧,即徹底銷毀,detach)
原文鏈接:https://blog.csdn.net/m0_70748845/article/details/126246670
相關(guān)推薦
- 2022-12-07 C++中的自定義函數(shù)返回類型_C 語言
- 2022-03-15 安裝zabbix遇到的問題
- 2022-04-08 iOS開發(fā)實現(xiàn)簡單計算器功能_IOS
- 2022-05-14 c++與python實現(xiàn)二分查找的原理及實現(xiàn)_C 語言
- 2022-08-30 ORACLE分區(qū)表轉(zhuǎn)換在線重定義DBMS_REDEFINITION_oracle
- 2022-11-24 nginx平滑升級及nginx配置文件詳解_nginx
- 2022-10-27 React的createElement和render手寫實現(xiàn)示例_React
- 2022-07-30 go?redis之redigo的使用_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支