Compose Navigation导航使用的部分注意事项

2024-04-02 17:28

本文主要是介绍Compose Navigation导航使用的部分注意事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、前言
  • 二、使用判断条件进行显示隐藏和Navigation的区别
  • 三、Navigation和ViewModel的关系
  • 四、Navigation中替换页面的方式

一、前言

Android的项目架构中有一种由单个Activity,多个页面组成的架构。页面之前是由Fragment来承载显示,现在可以使用Compose来承载显示。在Compose中进行页面跳转切换除了使用判断条件进行显示隐藏外,使用Navigation能更好的对项目进行拓展维护。

二、使用判断条件进行显示隐藏和Navigation的区别

大部分项目应该还是使用Activity或者Fragment进行承载Compose页面。有时候单个页面中有不同的状态比如有数据状态或者无数据状态的UI的话,可以使用条件判断进行能显示隐藏。假如想将多个复杂页面放在一个Activity中。比如登录功能中的登录、注册等页面,那么使用判断来做会显得过于耦合。使用Navigation的话就能很好的解耦。每个页面都有自己的示例,算是另一个版本的Fragment

三、Navigation和ViewModel的关系

如果使用Navigation进行UI显示的话,那么除非每一个页面的ViewModel是由外部生成传递进来的,那么每一个Navigation页面之间的ViewModel实例都是一个单独的实例。例如以下示例:

@Compose
fun Root(){NavHost(modifier = modifier,navController = navController,startDestination = firstRoute) {composable(firstRoute) {FirstPage().FirstRoot()}composable(route = secondRoute,) {SecondPage().SecondRoot()}}
}class FirstPage {@Preview(showBackground = true, showSystemUi = true)@Composablefun FirstRoot(viewModel: MainViewModel = viewModel()){Box(modifier = Modifier.fillMaxSize(),){TextButton() {Text(text = "第一个页面")}}}
}class SecondPage {@Preview(showBackground = true, showSystemUi = true)@Composablefun SecondRoot(viewModel: MainViewModel = viewModel()){Box(modifier = Modifier.fillMaxSize(),){TextButton() {Text(text = "第二个页面")}}}
}

如上文所述,两个页面之间的ViewModel之间的数据是不互通的。除非从外部传入,或者有一个公共的地方保存同一个ViewModel示例

四、Navigation中替换页面的方式

Navigation默认会对切换的页面保存在一个堆栈里面,假如按返回键的话会回退的上一个页面。但是假如某个Activity进去后会根据状态不同显示某个页面,比如先进去的时候有数据,网络不好了,切换到无数据UI,这时候是不能回退到上个页面的,有两种方式一种就是拦截返回操作,第二个就是跳转过来时候清空堆栈。示例代码如下

//第一种
navController.navigate(secondRoute){popUpTo(navController.graph.startDestinationId) {inclusive = true // 包含起始目标在内的所有目标}
}
//第二种
navController.navigate(secondRoute){popUpTo(navController.graph.id) {inclusive = true // 包含起始目标在内的所有目标}
}

这篇关于Compose Navigation导航使用的部分注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/870605

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

C#中,decimal类型使用

在Microsoft SQL Server中numeric类型,在C#中使用的时候,需要用decimal类型与其对应,不能使用int等类型。 SQL:numeric C#:decimal

探索Elastic Search:强大的开源搜索引擎,详解及使用

🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 引入 全文搜索属于最常见的需求,开源的 Elasticsearch (以下简称 Elastic)是目前全文搜索引擎的首选,相信大家多多少少的都听说过它。它可以快速地储存、搜索和分析海量数据。就连维基百科、Stack Overflow、