Fragment
- Fragment 可以视为 Activity 的一个片段,它具有自己的生命周期和接收事件的能力,它有以下特点
-
Fragment 依赖于 Activity,不能独立存在,Fragment 的生命周期受 Activity 的生命周期影响
-
Fragment 将 Activity 的 UI 和功能划分为更小的模块,便于管理维护
-
多个 Activity 可以重用同一个 Fragment,一个 Activity 也可以使用多个 Fragment
-
Fragment 可以动态地添加、移除、替换、隐藏,实现复杂的界面交互效果
创建 Fragment
1、通过 Android Studio 创建 Fragment
- 右击【包】 -> 【New】 -> 【Fragment】 -> 【Fragment(Blank)】,对于 Fragment Java 文件,命名尽量为
【Xxx】Fragment
,对于 Fragment XML 文件,命名尽量为fragment_【xxx】


- Android Studio 会自动在【包】下创建 Fragment Java 文件,在【layout 目录】下创建 Fragment XML 文件
/*** A simple {@link Fragment} subclass.* Use the {@link TestAFragment#newInstance} factory method to* create an instance of this fragment.*/
public class TestAFragment extends Fragment {// TODO: Rename parameter arguments, choose names that match// the fragment initialization parameters, e.g. ARG_ITEM_NUMBERprivate static final String ARG_PARAM1 = "param1";private static final String ARG_PARAM2 = "param2";// TODO: Rename and change types of parametersprivate String mParam1;private String mParam2;public TestAFragment() {// Required empty public constructor}/*** Use this factory method to create a new instance of* this fragment using the provided parameters.** @param param1 Parameter 1.* @param param2 Parameter 2.* @return A new instance of fragment TestAFragment.*/// TODO: Rename and change types and number of parameterspublic static TestAFragment newInstance(String param1, String param2) {TestAFragment fragment = new TestAFragment();Bundle args = new Bundle();args.putString(ARG_PARAM1, param1);args.putString(ARG_PARAM2, param2);fragment.setArguments(args);return fragment;}@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);if (getArguments() != null) {mParam1 = getArguments().getString(ARG_PARAM1);mParam2 = getArguments().getString(ARG_PARAM2);}}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {// Inflate the layout for this fragmentreturn inflater.inflate(R.layout.fragment_test_a, container, false);}
}
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".fragment.TestAFragment"><!-- TODO: Update blank fragment layout --><TextViewandroid:layout_width="match_parent"android:layout_height="match_parent"android:text="@string/hello_blank_fragment" /></FrameLayout>
- 对 Android Studio 自动创建的文件修修改改,在 Fragment Java 文件去除多余的代码和注释,在 Fragment XML 文件中修改控件(这里我更喜欢用 ConstraintLayout 控件),最后得到一个 Fragment 的框架
public class TestAFragment extends Fragment {@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_test_a, container, false);}
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".fragment.TestAFragment"></androidx.constraintlayout.widget.ConstraintLayout>
2、手动创建 Fragment
- 右击【layout 目录】 -> 【New】 -> 【file】,创建 Fragment XML 文件,该文件命名尽量为
fragment_【xxx】.xml


- 对于 Fragment Java 文件,继承 Fragment,实现 onCreateView 方法
public class TestBFragment extends Fragment {@Nullable@Overridepublic View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {return inflater.inflate(R.layout.fragment_test_b, container, false);}
}
-
右击【包】 -> 【New】 -> 【Java Class】,创建 Fragment Java 文件,该文件命名尽量为
【Xxx】Fragment
-
对于 Fragment Xml 文件,添加控件(这里我更喜欢用 ConstraintLayout 控件)
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".fragment.TestBFragment"></androidx.constraintlayout.widget.ConstraintLayout>