目录
1)Fragment是什么
2)Fragment的应用场景
3)为什么使用Fragment?
4)Fragment如何使用
5)Fragment的生命周期
6)Android开发,建议是多个activity,还是activity结合fragment,优缺点如何?
7)Fragment和Activity的通讯、返回键如何处理
8)Navigation搭配Fragment使用后,事务是怎么样?
一、Fragment是什么
Fragment是Android中的一种组件,直译为“碎片”或“片段”,可以看作是Activity的模块化部分。
它主要用于承载一部分用户界面和逻辑,并可以在多个Activity中复用。Fragment具有自己的生命周期,能接收输入事件,可以在Activity运行时被添加、移除、替换或隐藏。此外,Fragment还允许开发者通过FragmentManager来管理其生命周期和事务,如添加、删除、替换Fragment等。
二、Fragment的应用场景
导航
- UI一:
- UI二:
三、为什么使用Fragment?
- 通过将复杂的界面拆分成多个Fragment,每个Fragment负责一部分UI和逻辑,可以提高代码的复用性和可维护性。不同的Fragment可以专注于处理特定的UI或逻辑,使得代码更加清晰和易于管理。
- Fragment可以被多个Activity复用,提高了代码的复用率。在模块化开发中,一个Fragment可以代表一个独立的业务模块,从而在不同的地方重复使用。
四、Fragment如何使用
4.1 Fragment一般搭配navigation进行使用
(1)创建一个导航条+容器:也就是我们上面案例种的左边部分(导航条)和内容显示部分(容器)
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<com.google.android.material.navigation.NavigationView
android:id="@+id/bnv_main_navigationbar"
android:layout_width="300dp"
android:layout_height="match_parent"
android:background="@color/white"
android:paddingHorizontal="9dp"
app:itemBackground="@color/white"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:menu="@menu/backstage_menu_setting" />
<androidx.fragment.app.FragmentContainerView
android:id="@+id/home_fragmentcontainerview"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@drawable/dingdian_pic_background_sys"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toEndOf="@+id/bnv_main_navigationbar"
app:layout_constraintTop_toBottomOf="@+id/backstage_constraintlayout"
app:navGraph="@navigation/backstage_nav" />
</androidx.constraintlayout.widget.ConstraintLayout>
(2)那么导航条view和容器view我们已经创建出来,那么导航条的这些