热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

Android中Fragment的基本用法示例总结

Fragment是activity的界面中的一部分或一种行为,下面这篇文章主要给大家介绍了关于Android中Fragment的基本用法的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

前言

fragment 可认为是一个轻量级的Activity,但不同与Activity,它是要嵌到Activity中来使用的,它用来解决设备屏幕大小的不同,主要是充分利用界面上的空间,如平板上多余的空间。一个Activity可以插入多个Fragment,可以认为Fragment就是Activity上的一个View。

本文主要介绍了关于Android中Fragment的基本用法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

一、fragment管理

在activity动态加载fragment

加载fragment的布局不限,并不局限于FrameLayout

加载方法:(只有导入的fragment是v4包,才有getSupportFragmentManager())

 FragmentA fragment = new FragmentA();
 getSupportFragmentManager().beginTransaction()
  .add(R.id.XXX, fragment, "fragment")
//  .addToBackStack("") //加入回退栈
  .commit;

或者

FragmentManager manager = getSupportFragmentManager(); 
FragmentTransaction transaction = manager.beginTransaction(); 
transaction.add(R.id.fragment_container, fragment, "fragment"); 
transaction.commit(); 

但是第二种方法要注意,导包须一致

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;

而除了使用add方法,我们也可以使用replace方法添加fragment

FragmentA fragment = new FragmentA();
getSupportFragmentManager().beginTransaction()
 .replace(R.id.XXX, fragment,"fragment")
 .commit();

add和replace的区别是:

①add 是往container容器里堆加fragment View;replace是将container容器里之前添加的View全部清除,然后再添加当前fragment View

一定要记住,replace清除的是container的视图,而不是fragment实例, remove移除的才是fragment实例

②add后期可以使用show,hide操作,但是replace不可以,原因见①

③使用add,回滚时,fragment不会重新加载,曾经的操作痕迹还存在,使用replace回滚时,之前的fragment会重新加载,原因见①

使用add的时候还有一点需要注意的是,视图重叠的问题,记得设置背景色

add 和 replace 千万不要混合使用,否则会出错

在进行remove,hide,show之前要记得判断fragment.isAdded();下面的代码我就不提示了

移除fragment实例

 Fragment fragment = getSupportFragmentManager().findFragmentByTag("fragment");
 getSupportFragmentManager().beginTransaction()
  .remove(fragment)
  .commit();

隐藏fragment

 Fragment fragment = getSupportFragmentManager().findFragmentByTag("fragment");
 getSupportFragmentManager().beginTransaction()
  .hide(fragment)
  .commit();

显示fragment

 Fragment fragment = getSupportFragmentManager().findFragmentByTag("fragment");
 getSupportFragmentManager().beginTransaction()
  .show(fragment)
  .commit();

拓展:

在fragment里刷新(即从头加载fragment数据,且不影响后续的回退栈)

Fragment replaceFragment = getActivity().getSupportFragmentManager().findFragmentByTag("first_fragment");
    getActivity().getSupportFragmentManager().beginTransaction()
    .detach(replaceFragment)
    .attach(replaceFragment)
    .commit();

简单的讲,detach是销毁View,而不是fragment实例,attach是重建视图View,attach后的视图会位于视图最前面,具体的可以自己去查看资料

二、回滚操作

最常用:依次回滚

 @Override
 public void onBackPressed() {
 if (getSupportFragmentManager().getBackStackEntryCount() <= 1) { //这里是取出我们返回栈存在Fragment的个数
  finish();
 } else { //取出我们返回栈保存的Fragment,这里会从栈顶开始弹栈
  getSupportFragmentManager().popBackStack();
 }
 }

拓展:指定回滚

void popBackStack(String name, int flags); 

参数string name是transaction.addToBackStack(String tag)中的tag值;

至于int flags有两个取值:0或FragmentManager.POP_BACK_STACK_INCLUSIVE

      当取值0时,表示除了参数一指定这一层之上的所有层都退出栈,指定的这一层为栈顶层;

      当取值POP_BACK_STACK_INCLUSIVE时,表示连着参数一指定的这一层一起退出栈;

退回栈顶:

while (getSupportFragmentManager().getBackStackEntryCount()>1) {
 getSupportFragmentManager().popBackStackImmediate();
}

三、重点来了,在fragment里面加载fragment 显示问题

1.显示不出来:

加载fragment的布局不要使用LinearLayout,不要使用LinearLayout,不要使用LinearLayout,重要的事情说三遍,否则很有可能加载的fragment显示不出来

2.显示不完全:在onCreateView使用方式一,不要使用方式二

 @Override
 public View onCreateView(LayoutInflater inflater, ViewGroup container,
    Bundle savedInstanceState) {
 // 方式一
 View view = inflater.inflate(R.layout.XXX, container, false);
  // 方式二
// View view = inflater.inflate(R.layout.XXX, null);
 return view;
 }

3.点击事件透传

①如果加载的fragment的布局为ScrollView,不会发生透传事件

②如果存在透传事件,在fragment的根布局加上android:clickable="true" ,即可简单粗暴的解决点击事件穿透的问题

4.获取回退栈中fragment的数量

方式一:activity如继承FragmentActivity,可通过getSupportFragmentManager().getBackStackEntryCount()判断activity中栈内已存的fragment的数量,不包括通过方式二加载进去的fragment(在fragment中加载子fragment)

方式二:此方式是在fragment中通过getChildFragmentManager().getBackStackEntryCount()判断此fragment栈内已存的fragment的数量

getChildFragmentManager().beginTransaction()
 .replace(R.id.XXX, fragment)
 .addToBackStack(null)
 .commit();

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。


推荐阅读
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • SQLite是一种轻量级的关系型数据库管理系统,尽管体积小巧,却能支持高达2TB的数据库容量,每个数据库以单个文件形式存储。本文将详细介绍SQLite在Android开发中的应用,包括其数据存储机制、事务处理方式及数据类型的动态特性。 ... [详细]
  • 对于初次购买阿里云服务器的新手用户来说,如何高效地利用服务器资源并成功部署网站是一个重要的课题。本文将详细指导您完成从购买服务器到网站上线的六个关键步骤。 ... [详细]
  • 本文详细介绍了如何在Vue项目中集成和配置XGPlayer视频插件,包括安装步骤、基本配置以及常见问题的解决方法。 ... [详细]
  • Kubernetes 实践指南:初次体验
    本文介绍了如何通过官方提供的简易示例,快速上手 Kubernetes (K8S),并深入理解其核心概念和操作流程。 ... [详细]
  • 深入解析Nacos服务自动注册机制
    本文将探讨Nacos服务自动注册的具体实现方法,特别是如何通过Spring事件机制完成服务注册。通过对Nacos源码的详细分析,帮助读者理解其背后的原理。 ... [详细]
  • 微服务自动化.dockercompose
    目录一、docker-compose二、docker-compose安装与配置1、修改docker.service2、下载文件3、将刚才下载的docker-compose文 ... [详细]
  • SpringBoot底层注解用法及原理
    2.1、组件添加1、Configuration基本使用Full模式与Lite模式示例最佳实战配置类组件之间无依赖关系用Lite模式加速容器启动过程,减少判断配置类组 ... [详细]
  • 本文探讨了在不同场景下如何高效且安全地存储Token,包括使用定时器刷新、数据库存储等方法,并针对个人开发者与第三方服务平台的不同需求提供了具体建议。 ... [详细]
  • 本文探讨了一个Web工程项目的需求,即允许用户随时添加定时任务,并通过Quartz框架实现这些任务的自动化调度。文章将介绍如何设计任务表以存储任务信息和执行周期,以及如何通过一个定期扫描机制自动识别并加载新任务到调度系统中。 ... [详细]
  • Docker运行中实例端口映射调整方法
    本文探讨了在Docker容器运行期间调整端口映射的方法,包括前期规划与运行时需求变更两种常见场景下的解决方案。 ... [详细]
  • 春季职场跃迁指南:如何高效利用金三银四跳槽季
    随着每年的‘金三银四’跳槽高峰期的到来,许多职场人士都开始考虑是否应该寻找新的职业机会。本文将探讨如何制定有效的职业规划、撰写吸引人的简历以及掌握面试技巧,助您在这关键时期成功实现职场跃迁。 ... [详细]
  • 本文探讨了如何在Docker构建过程中使用动态环境变量,特别是针对Docker v1.9及以上版本的用户。我们将介绍如何声明和使用构建参数,以及这些参数对构建缓存的影响。 ... [详细]
  • 函子(Functor)是函数式编程中的一个重要概念,它不仅是一个特殊的容器,还提供了一种优雅的方式来处理值和函数。本文将详细介绍函子的基本概念及其在函数式编程中的应用,包括如何通过函子控制副作用、处理异常以及进行异步操作。 ... [详细]
author-avatar
用户7kxpkjs2ol
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有