SwiftUI导航SplitView(sprite导航)
yuyutoo 2025-03-25 19:21 9 浏览 0 评论
NavigationSplitView是用于导航的SwiftUI组件,在每个苹果平台上看起来都很棒。如果您想知道它是如何工作的或如何实现NavigationSplitView,这是开始查看的文章。
在我们开始之前,请花几秒钟关注我,为这篇文章鼓掌,这样我们就可以帮助更多的人了解这个有用的内容。
什么是NavigationSplitView
NavigationSplitView是一个组件,允许用户在iPhone Pro Max(仅在横向模式下)、iPad、Mac和Apple TV等大型设备上同时查看更多详细信息,特别是导航。虽然NavigationSplitView在大屏幕上看起来可能很棒,但在小屏幕上也运行良好。例如,在iPad(在滑动模式下)、iPhone SE或Apple Watch上,导航的额外细节被隐藏起来,并像常规的单列NavigationStack一样自动工作。如果您不熟悉NavigationStack的工作原理,请查看我在这里写的文章:https://medium.com/@
jpmtech/navigationstack-in-swiftui-d89a61bd8963
NavigationSplitView是什么样子的
我也想知道同样的事情,所以我运行了几个不同的模拟器来找到答案。在下面的屏幕截图中,我在第一、第二和第三视图中使用了红色、绿色和蓝色(因为RGB LED很棒)来说明导航SplitView的每个配置的工作原理。说到配置,苹果默认为我们提供了两种不同的配置。第一个是两列布局,第二个是三列布局。我在这里说“默认”,因为您可以在NavigationSplitView中嵌入NavigationStack,这样您就不必将所有导航都只放入三个视图中。如果您想直接跳转到实现自己的拆分视图,而不是看图片,请随时跳转到下一节,在那里您将了解如何构建自己的NavigationSplitView。
注意:在有多个方向屏幕截图的情况下,这意味着系统可以免费使用内置导航按钮,并按下它以获取新的屏幕截图。
在iPhone 15 Pro上查看2列拆分视图,纵向和横向视图如下所示(注意当没有足够的空间时,NavigationSplitView如何缩小到单列):
在iPhone 15 Pro Max上查看2列拆分视图,纵向和横向视图如下所示:
在12.9英寸的iPad上查看2列分体视图,纵向和横向视图如下所示:
由于即使在3列布局中,iPhone Pro也不会从2列布局改变,我们将跳过显示2列布局显示的相同图像。
在iPhone 15 Pro Max上查看3列拆分视图,纵向和横向视图如下所示:
在12.9英寸的iPad上查看3列拆分视图,纵向和横向视图如下所示:
构建导航SplitView
现在我们知道每个配置是什么样子的以及它是如何运行的,让我们开始构建一个。
第一个代码块为我们提供了一个基本的数据结构,我们可以使用它,并允许我们轻松地将样本数据传递到下一个块的视图中。
// DataModel.swift
进口基金会
结构数据模型:可识别,可散列{
让id = UUID()
让文本:字符串
}
类 SampleData {
静态 let firstScreenData = [
数据模型(文本:“火车”),
数据模型(文本:“平面”),
数据模型(文本:“汽车”),
]
静态让 secondScreenData = [
数据模型(文本:“慢”),
数据模型(文本:“常规”),
数据模型(文本:“快速”),
]
静态 let lastScreenData = [
数据模型(文本:“错误”),
数据模型(文本:“so-so”),
数据模型(文本:“右”),
]
}
下面的代码设置了三列NavigationSplitView,每个部分显示不同的数据列表。我们还在列表上方的文本组件中显示之前选择的项目,这演示了在NavigationSplitView中将数据从一个屏幕传递到下一个屏幕的样子(我们也可以使用视图模型或环境变量来完成相同的任务,但为了教程,这变得简单了)。NavigationSplitView的每个尾随闭包都会获取/显示传递给它的视图。
// ThreeColumnSampleCode.swift
导入SwiftUI
struct ThreeColumnSampleCode:视图{
@State private var firstSelectedDataItem:数据模型?
@State private var secondSelectedDataItem:DataModel?
@State private var thirdSelectedDataItem:数据模型?
var body:一些视图{
导航SplitView {
列表(SampleData.firstScreenData,选择:$firstSelectedDataItem){项目
NavigationLink(item.text,值:item)
}
.导航标题(“边栏”)
} 内容:{
VStack(对齐:.leading){
如果firstSelectedDataItem!= nil {
文本(“之前选择的项目:\(firstSelectedDataItem!.text)”)
}
列表(SampleData.secondScreenData,选择:$secondSelectedDataItem){项目
NavigationLink(item.text,值:item)
}
.navigationTitle(“内容”)
}.填充()
} 详细信息:{
VStack(对齐:.leading){
如果secondSelectedDataItem!= nil {
文本(“先前选择的项目:\(secondSelectedDataItem!.text)”)
.padding()
}
列表(SampleData.lastScreenData,选择:$thirdSelectedDataItem){项目
文本(item.text)
}
}
.navigationTitle(“详细信息”)
}
}
}
#预览 {
ThreeColumnSampleCode()
}
在iPad模拟器中的iPhone 15和12.9中运行此示例会给我们带来以下结果:
我们也可以通过简单地从三栏布局中删除“内容”部分,在两列布局中构建相同的示例。我们也可以使用NavigationStack在“详细信息”部分中继续导航。
相关推荐
- java把多张图片导入到PDF文件中(java如果导入图片到项目)
-
packagecom.mlh.utils;importcom.itextpdf.text.*;importcom.itextpdf.text.Font;importcom.itextp...
- 聊聊langchain4j的AiServicesAutoConfig
-
序本文主要研究一下langchain4j-spring-boot-starter的AiServicesAutoConfig...
- Spring 中三种 BeanName 生成器!(spring生成bean过程)
-
无论我们是通过XML文件,还是Java代码,亦或是包扫描的方式去注册Bean,都可以不设置BeanName,而Spring均会为之提供默认的beanName,今天我们就来看看Spr...
- Zookeeper实现微服务统一配置中心
-
Zookeeper介绍本质它是一个分布式服务框架,是ApacheHadoop的一个子项目...
- 从Nacos客户端视角来分析一下配置中心实现原理
-
目录...
- Python 中容易被新手忽略的问题(python容易犯的错误)
-
设置全局变量有时候设置全局变量的需求并不是直接赋值,而是想从某个数据结构里引用生成,可以用下面这两种方法,推荐第二种,golbals()支持字典用法很方便。...
- Springboot实现对配置文件中的明文密码加密
-
我们在SpringBoot项目当中,会把数据库的用户名密码等配置直接放在yaml或者properties文件中,这样维护数据库的密码等敏感信息显然是有一定风险的,如果相关的配置文件被有心之人拿到,必然...
- 是时候丢掉BeanUtils了(丢掉了时间)
-
前言为了更好的进行开发和维护,我们都会对程序进行分层设计,例如常见的三层,四层,每层各司其职,相互配合。也随着分层,出现了VO,BO,PO,DTO,每层都会处理自己的数据对象,然后向上传递,这就避免不...
- EasyExcel自定义合并单元格多行合并根据自定义字段
-
第一种方式实现通过定义注解+实现RowWriteHandler接口中的afterRowDispose方法来动态合并行根据指定的key可以是单个字段也可以是多个字段也可以根据注解指定。注解方式使用参考原...
- 太香了!女朋友熬夜帮我整理的Spring Boot - Banner 笔记,分享给你
-
上一篇分享的是《Java避坑指南!IDEA查看.class文件源码下载失败问题汇总》,这篇给大家分享《SpringBoot-自定义Banner图案》。...
- 基于SpringCloud的enum枚举值国际化处理实践
-
背景选用SpringCloud框架搭建微服务做业务后台应用时,会涉及到大量的业务状态值定义,一般常规做法是:持久层(数据库)存储int类型的值后台系统里用阅读性好一点儿的常量将int类型的值做一层映射...
- Lucene就是这么简单(好女婿你以后就是妈妈的老公了)
-
什么是Lucene??Lucene是apache软件基金会发布的一个开放源代码的全文检索引擎工具包,由资深全文检索专家DougCutting所撰写,它是一个全文检索引擎的架构,提供了完整的创建索引和...
- 注解@Autowired和@Resource的区别总结
-
零、前言@Autowired和@Resource注解都可以在Spring应用中进行声明式的依赖注入。以前都是看的网上关于两者的区别,但是实际和网上说的有出入,故从源码角度进行分析、验证。...
- 100个Java工具类之73:系统信息获取工具类SystemUtils
-
SystemUtils是一个功能强大的工具类。可以获取系统属性、检测java版本、处理跨平台文本文件,合理地使用此类,可以使代码更健壮,系统更安全。...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
-
- java把多张图片导入到PDF文件中(java如果导入图片到项目)
- 聊聊langchain4j的AiServicesAutoConfig
- Spring 中三种 BeanName 生成器!(spring生成bean过程)
- Zookeeper实现微服务统一配置中心
- Spring cloud Gateway 动态路由(springboot gateway 动态路由)
- 从Nacos客户端视角来分析一下配置中心实现原理
- Python 中容易被新手忽略的问题(python容易犯的错误)
- Springboot实现对配置文件中的明文密码加密
- 是时候丢掉BeanUtils了(丢掉了时间)
- EasyExcel自定义合并单元格多行合并根据自定义字段
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)