首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android入门教程 | Fragment 基础概念

可以将片段视为 Activity 的模块化组成部分,它具有自己的生命周期,能接收自己的输入事件,并且可以在 Activity 运行时添加或移除片段(这有点像可以在不同 Activity 中重复使用的“子...可以通过两种方式向 Activity 布局添加片段(以下为代码片段,并非完整代码)。 静态方式 在 Activity 的布局文件内声明片段。 在本例中,您可以将片段当作视图来为其指定布局属性。...Java代码加载Fragment 或者,通过编程方式将片段添加到某个现有 ViewGroup。 在 Activity 运行期间,您可以随时将片段添加到 Activity 布局中。...执行Fragment事务 在 Activity 中使用片段的一大优点是,可以通过片段执行添加、移除、替换以及其他操作,从而响应用户交互。...正确的切换方式是 add(),切换时 hide(),add()另一个 Fragment;再次切换时,只需 hide()当前,show()另一个。

3.5K40

Fragment初识

当然了我们普通手机开发也会加入这个Fragment, 我们可以把它看成一个小型的Activity,又称Activity片段!...例如:新闻应用可以使用一个片段在左侧显示文章列表,使用另一个片段在右侧显示文章—两个片段并排显示在一个 Activity 中,每个片段都具有自己的一套生命周期回调方法,并各自处理自己的用户输入事件。...我们应该将每个片段都设计为可重复使用的模块化 Activity 组件。...也就是说,由于每个片段都会通过各自的生命周期回调来定义其自己的布局和行为,您可以将一个片段加入多个 Activity,因此,您应该采用可复用式设计,避免直接从某个片段直接操纵另一个片段。...这特别重要,因为模块化片段让您可以通过更改片段的组合方式来适应不同的屏幕尺寸。 在设计可同时支持平板电脑和手机的应用时,您可以在不同的布局配置中重复使用您的片段,以根据可用的屏幕空间优化用户体验。

1.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    你不知道的 DOM 变动观察器:Mutation observer

    我们将首先看一下语法,然后探究一个实际的用例,以了解它在什么地方有用。 语法 MutationObserver 使用简单。...characterData —— 是否观察 node.data(文本内容), 其他几个选项: attributeOldValue —— 如果为 true,则将特性的旧值和新值都传递给回调(参见下文),否则只传新值...使用 MutationObserver,我们可以监测到我们不需要的元素何时出现在我们的 DOM 中,并将其删除。...假设我们正在建立一个有关编程的网站。自然地,文章和其他材料中可能包含源代码段。 在 HTML 标记(markup)中的此类片段如下所示: ......我们找到 HTML 中的代码片段并高亮显示它们。 现在让我们继续。假设我们要从服务器动态获取资料。我们将 在本教程的后续章节[4] 中学习进行此操作的方法。

    2.2K10

    无需框架,就能实现微前端,理解起来通俗易懂

    为什么需要微前端 假设你正在一个项目中使用一个特定的框架或库(比如React.js),但你需要切换到另一个框架或库,或者添加另一个在另一个框架(比如Angular.js)上编写的模块。...如果你不需要改变任何东西,你可以用你选择的另一个框架开始添加新模块呢?这就是微前端出现的地方。...根据我们的要求,我们可以用相当多的方式来做到这一点。让我们来看看下面的一些想法: 功能 这是最常用的划分,我们将在这里划分应用程序的特性或模块。...我们可以按页面来划分应用程序,使用这种方法时,每个页面都有独立的功能。 域 应用程序也可以按域划分。例如,我们可以根据我们的需求将应用程序划分为核心域、支付域或配置文件域。...你可以将较小的应用组合起来,使用微前端创建大型前端应用,但将其应用于所有类型的应用是不明智的。理解您的应用程序可以让你更清楚地了解实现微前端的场景,以便以最好的方式利用它们的好处。

    2.1K20

    ES6学习之函数传参

    Arguments中的扩展运算符 在ECMAScript 5中我们经常需要使用apply()这类转换工具将数组传递给函数,比如采用Math.max()求数组中最大元素,由于该方法不支持数组作为参数,而apply...apply()来将数组拆分为单个元素外,还提供了更直观的语义和灵活性,比如在一次函数调用中可以多次使用,也能和其他常规Arguments混合使用。...or 传引用 对于其他语言来讲,传参分为传值类型和传引用(指针)类型。...从技术层面来讲,javascript参数的传递方式全部都是传值类型,当我们将一个值传递到函数内部时,一个临时的局部变量会被创建,形成对这个参数的一个拷贝,任何对该值的改变都不会影响原有的外部变量。...(或数组)作为参数传递给函数的时候,虽然还是按值传递,但由于该值实际上映射的是此对象(或数组)在内存中的一片区域,所以当我们修改此对象的属性(或数组的某一个元素)的时候,实际上是操作了公用的一片内存区域

    1.9K20

    ES6学习之函数传参

    Arguments中的扩展运算符 在ECMAScript 5中我们经常需要使用apply()这类转换工具将数组传递给函数,比如采用Math.max()求数组中最大元素,由于该方法不支持数组作为参数,而apply...apply()来将数组拆分为单个元素外,还提供了更直观的语义和灵活性,比如在一次函数调用中可以多次使用,也能和其他常规Arguments混合使用。...or 传引用 对于其他语言来讲,传参分为传值类型和传引用(指针)类型。...从技术层面来讲,javascript参数的传递方式全部都是传值类型,当我们将一个值传递到函数内部时,一个临时的局部变量会被创建,形成对这个参数的一个拷贝,任何对该值的改变都不会影响原有的外部变量。...(或数组)作为参数传递给函数的时候,虽然还是按值传递,但由于该值实际上映射的是此对象(或数组)在内存中的一片区域,所以当我们修改此对象的属性(或数组的某一个元素)的时候,实际上是操作了公用的一片内存区域

    1.6K20

    ES6学习之函数传参

    Arguments中的扩展运算符 在ECMAScript 5中我们经常需要使用apply()这类转换工具将数组传递给函数,比如采用Math.max()求数组中最大元素,由于该方法不支持数组作为参数,而apply...apply()来将数组拆分为单个元素外,还提供了更直观的语义和灵活性,比如在一次函数调用中可以多次使用,也能和其他常规Arguments混合使用。...or 传引用 对于其他语言来讲,传参分为传值类型和传引用(指针)类型。...从技术层面来讲,javascript参数的传递方式全部都是传值类型,当我们将一个值传递到函数内部时,一个临时的局部变量会被创建,形成对这个参数的一个拷贝,任何对该值的改变都不会影响原有的外部变量。...(或数组)作为参数传递给函数的时候,虽然还是按值传递,但由于该值实际上映射的是此对象(或数组)在内存中的一片区域,所以当我们修改此对象的属性(或数组的某一个元素)的时候,实际上是操作了公用的一片内存区域

    2K100

    善用TableLayout表格布局,事半功倍

    一、认识TableLayout 表格布局就是让控件以表格的形式来排列控件,只要将控件放在单元格中,控件就可以整齐地排列,使用TableLayout>标签。...每次向TableLayout中添加一个TableRow,该TableRow就是一个表格行,TableRow也是容器,因此它也可以不断地添加其他组件,每添加一个子组件该表格就增加一列。...如果直接向TableLayout中添加组件,那么这个组件将直接占用一行。...在表格布局管理器中,可以为单元格设置如下3种行为方式。 Shrinkable:如果某个列被设为Shrinkable,那么该列的所有单元格的宽度可以被收缩,以保证该表格能适应父容器的宽度。...同样使用WidgetSample工程,继续使用app/main/res/layout/目录下的activity_main.xml文件,在其中填充如下代码片段: <?

    1.7K90

    Linux|Grep 命令的 12 个实用示例

    如果你能删除所有注释行,对你、帮助你的人以及阅读它的每个人来说不是更容易吗?好吧,你可以!...i 以过滤并打印名称为“JayZ”的所有文件,然后将另一个管道传输到 grep –vi 进行过滤out 并且不会打印带有字符串(在任何情况下)“remix”的所有文件名。...搜索整个模式 将 -w 选项传递给 grep 会搜索字符串中的整个模式。例如,使用: ifconfig | grep -w "RUNNING" 将打印出包含引号中的模式的行。...匹配文件中的正则表达式 egrep 命令是另一个派生命令,代表“扩展全局正则表达式”。它可以识别其他表达式元字符,例如 + ? |和 ()。...如果需要的话,egrep 命令对于搜索源文件和其他代码片段非常有用。可以通过指定 -E 选项从常规 grep 调用它。 grep -E 12.

    34310

    如何设计一个C++的类?

    片段可以复制吗?轨道可以移动吗?片段可以移动吗?...然后我们就可以进一步将现实世界中的轨道和片段抽象成类了,可分为两个类,一个轨道类,一个片段类,两个类是否需要提供拷贝构造函数和移动构造函数,完全取决于它们在现实世界的样子。...其实不标const也不会有任何问题,但是如果我们期望某个函数内不会修改任何成员变量时,应该把该成员函数标记为const,这样可以防止自己或者其它程序员误操作,当误更改了某些成员变量时,编译器会报错。...这里抛砖引玉下,如果是服务端编程,建议使用异常处理替代错误码的错误处理方式,关于异常处理有两个常见问题: 构造函数可以使用异常吗 析构函数可以使用异常吗?...最少知道原则:一个实体应该尽可能少的与其他实体发生相互作用。 将变化的点进行封装,做好分界,保持一侧变化,一侧稳定,调用侧永远稳定,被调用测内部可以变化。

    1.6K20

    C++:引用及其应用

    引用 引用是个别名,当建立引用时,程序用另一个变量或对象的名字初始化它,从那时起,引用就作为目标的别名而使用,对引用的改动就相当于对目标的改动。...要建立一个引用,需要在目标类型后面接上引用运算符“&”,然后是引用名(可以使用任何合法的变量名)。...我们学习过 C 语言将知道,数组名本质是数组的首地址,是一个 const 型的指针,如果我们要对一个数组进行引用,那么将意味着数组中的每一个元素都要初始化为其他的内存实体,显然不现实;另一方面,数组名代表的是整个数组空间的起始地址...int& *p= &num ;//error无引用的指针 int& r= null;//无意义 int& ri=int;//引用是对变量或对象的引用,而不是对一种类型的引用 用引用传参 以前我们想通过函数对变量进行处理...func2 ()函数返回一个引用,因此不产生任何返回值的副本,当然,这个返回值需要使用全局变量或静态变量,避免函数结束后,该变量被释放。 略...

    85010

    Fragment基本使用

    Fragment概述 1.1 介绍 Fragment是一种可以嵌入在活动中的UI片段,能够让程序更加合理和充分地利用大屏幕的空间,出现的初衷是为了适应大屏幕的平板电脑,可以将其看成一个小型Activity...,并能接收输入事件 可以在Activity运行时动态地添加或删除Fragment Fragment的优势: 模块化(Modularity):我们不必把所有代码全部写在Activity中,而是把代码写在各自的...方式添加,在由于内存紧张导致Fragment被系统杀掉并恢复(re-instantiate)时能保留这些数据 可以在Fragment的onAttach()中通过getArguments()获得传进来的参数...()获得任何Fragment实例,然后进行操作 在Fragment中可以通过getActivity得到当前绑定的Activity的实例,然后进行操作。...如何获取其他Fragment页控件的引用?

    2K30

    Android之布局详解

    ——android:layout_weight.这个属性允许我们使用比例的方式来指定控件的大小,它在手机屏幕的适配性方面可以起到非常重要的作用。...他可以通过相对定位的方式让控件出现在布局的任何位置,,也正因为如此,RelativeLayout中的属性非常多,不过这些属性都是有规律可循的,其实不难理解和记忆。...android:layout_above属性可以让一个空间位于另一个控件的上方,需要为这个属性指定相对控件id的引用,这里我们填入了@id/button3,表示让该控件位于Button3的上方。...相信学过HTML的朋友都知道,我们可以通过就可以生成一个HTML的表格, 而Android中也允许我们使用表格的方式来排列组件,就是行与列的方式,就说我们这节的...如何确定行数与列数 ①如果我们直接往TableLayout中添加组件的话,那么这个组件将占满一行!!! ②如果我们想一行上有多个组件的话,就要添加一个TableRow的容器,把组件都丢到里面!

    2K10

    Android系统五大布局详解Layout

    在分析布局之前,我们首先看看控件:Android中任何可视化的控件都是从android.veiw.View继承而来的,系统提供了两种方法来设置视图:第一种也是我们最常用的的使用XML文件来配置View的相关属性...第二种是我们在代码中直接使用相应的类来创建视图。 如何使用XML文件定义视图: 每个Android项目的源码目录下都有个res/layout目录,这个目录就是用来存放布局文件的。...这些布局都可以嵌套使用。 (1)LinearLayout 线性布局 线性布局是按照水平或垂直的顺序将子元素(可以是控件或布局)依次按照顺序排列,每一个元素都位于前面一个元素之后。...现在我们只需要按照正比例来设置就可以。...注意:在TableLayout中,单元格可以为空,但是不能跨列,意思是只能不能有相邻的单元格为空。

    2.8K10
    领券