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

SwiftUI - NavigationLink返回到上一个视图

SwiftUI是一种用于构建iOS、macOS、watchOS和tvOS应用程序的用户界面工具包。它是苹果公司推出的一种声明式UI框架,旨在简化界面开发过程并提供更好的用户体验。

NavigationLink是SwiftUI中的一个视图导航控件,用于在应用程序中实现视图之间的导航。它允许用户通过点击链接来切换到其他视图,并提供了返回上一个视图的功能。

要实现NavigationLink返回到上一个视图,可以使用SwiftUI中的@Environment关键字和presentationMode属性。首先,在目标视图中,使用@Environment关键字声明一个presentationMode属性,如下所示:

@Environment(.presentationMode) var presentationMode

然后,在目标视图中,可以使用presentationMode属性来返回到上一个视图,如下所示:

Button(action: { self.presentationMode.wrappedValue.dismiss() }) { Text("返回") }

在这个例子中,当用户点击返回按钮时,presentationMode属性的dismiss()方法将被调用,从而返回到上一个视图。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云移动开发平台:https://cloud.tencent.com/product/mpp
  • 腾讯云云原生应用引擎:https://cloud.tencent.com/product/nae
  • 腾讯云数据库:https://cloud.tencent.com/product/cdb
  • 腾讯云服务器:https://cloud.tencent.com/product/cvm
  • 腾讯云人工智能:https://cloud.tencent.com/product/ai
  • 腾讯云物联网:https://cloud.tencent.com/product/iot
  • 腾讯云存储:https://cloud.tencent.com/product/cos
  • 腾讯云区块链:https://cloud.tencent.com/product/baas
  • 腾讯云元宇宙:https://cloud.tencent.com/product/mu
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

SwiftUI 4.0 的全新导航系统

受 NavigationView 的能力限制,开发者需要动用各种技巧乃至黑科技才能实现一些本应具备基本功能(例如:返回视图、向堆栈添加任意视图返回任意层级视图 、Deep Link 跳转等 )。...使用新的编程式 API ,开发者可以轻松地实现例如:返回视图、在当前视图堆栈中添加任意视图视图跳转 )、视图外跳转( Deep Link )等功能。...>, @ViewBuilder destination: () -> Destination) 上述两种方法有一定的局限性: 需要逐级视图进行绑定,开发者如想实现返回任意层级视图则需要自行管理状态 在声明...browser 在 iPad 下,当前视图的 Title 将显示在左侧 image-20220612190914949 editor 不显示返回按钮旁边的上页视图 Title image-20220612191040190...定制 NavigationLink 样式 在之前版本的 SwiftUI 中,NavigationLink 其实一直都是作为一种特殊的 Button 存在的。

10.3K62

用NavigationViewKit增强SwiftUI的导航视图

有以下几个我不满意的地方: •缺少直接返回视图的便捷手段•无法通过代码(不通过NavigationLink)跳转到新视图•双栏模式(DoubleColumnNavigationViewStyle)下显示风格不统一...最大抱怨之一就是不支持便捷的返回视图手段。...,鱼和熊掌不可兼得•使用程序化的NavigationLink通过撤销根视图的程序化的NavigationLink(通常是isActive)来返回。...下的任意视图通过代码直接返回视图•在NavigationView下的任意视图中通过代码直接跳转到新视图(无需在视图中描述NavigationLink)•通过NotificatiionCenter,指定应用程序中的任意...从视图返回视图 在注册过的NavigationView的任意子视图中,可以通过下面的代码实现返回视图: @Environment(\.navigationManager) var nvmanager

3.2K20

如何让 SwiftUI 的列表变得更加灵活

前言 List 可能是 SwiftUI 附带的内置视图中最常用的一种,它使我们能够在任何 Apple 平台上呈现“类似于表格视图”的用户界面。...使用新速记语法 让我们从一个很小的特性开始,这是一个非常受欢迎的变化,可以使用类似 enum 的速记语法来引用 SwiftUI 附带的任何内置 ListStyle 类型。...为了演示这种情况,我们在 List 中嵌套一个 ForEach (因为在 SwiftUI 的中,列表变化一版都是由 ForEach 触发的,而不是由 List 触发的)。...由于每个 article 值在 ForEach 闭包中都是可变的,我们可以使用新的 swipeActions 修饰符来实现每个 NavigationLink 项目视图的自定义滑动操作。...可定制的分隔符 自从引入 SwiftUI 以来,开发者们有一个非常普遍的要求,提供一个 API ,用于隐藏或以其他自定义实现列表中每个 item 之间的默认分隔符。

4.8K41

SwiftUI 与 Core Data —— 安全地响应数据

也就是说,如果一个用于显示托管对象实例数据的视图被销毁了,那么假如没有其他的视图或代码引用视图中显示的托管对象实例,托管上下文将从内存中将这些数据占用的内存释放掉。..., formatter: itemFormatter)")因此在 ContentView 的 ForEach 中,item 并不会被视为一个可以引发视图更新的 Source of truth ( 通过...随着 FetchRequest 的内容发生变化,List 将重新刷新,由于 NavigationLink 对应的数据不复存在,因此 NavigationView 自动返回了根视图。...在上节的演示中,当数据被删除后( 通过 onAppear 闭包中的延迟操作 ),NavigationView 会自动返回到根视图中。在这种情况下,持有该数据的视图将伴随着数据删除一并消失。...但在非常多的情况下,开发者并不会使用演示中使用的 NavigationLink 版本,为了对视图拥有更强地控制力,开发者通常会选择具备可编程特性的 NavigationLink 版本。

3.3K20

解析SwiftUI布局细节(二)循环轮播+复杂布局

NavigationView + NavigationLink 的界面跳转,在苹果给的 SwiftUI 的使用例子中就是这样写的,当然我们在正常的使用中这样写也没啥问题,那我们界面跳转的问题是什么呢?...GeometryReader 的主要作用就是能够获取到父View建议的尺寸,这就是它的主要作用,要没有它我们面临的可能就是无休止的传值了,SwiftUI 既然是声明式的UI,按我的理解你就没有办法去获取某一个视图的父视图之类的...public func frame(in coordinateSpace: CoordinateSpace) -> CGRect } * size 比较直观,就是返回父View建议的尺寸...3、再提一点关于上面说的滚动视图,在UIKit中我们可以用UICollectionView搞定一切,但是在SwiftUI中没有这个控件,我建议采用的方式是 ScrollView + HStack + VStack...的方式去实现,很多同行有说目前来看SwiftUI的List在数据量大的情况下性能不是特别好,采用ScrollView是个不错的方式,而且也很容易构建出来,并不是说每一个Item的位置都需要你去计算,

11.9K20

SwiftUI-数据流

A Single Source Of Truth: 保持单一数据源,在 SwiftUI 中不同视图之间如果要访问同样的数据,不需要各自持有数据,直接共用一个数据源即可,这样做的好处是无需手动处理视图和数据的同步...NavigationLink(destination: DetailView()) { Text("下一个界面")...数据流图 从上图可以看出SwiftUI 的数据流转过程: 用户对界面进行操作,产生一个操作行为 action 该行为触发数据状态的改变 数据状态的变化会触发视图重绘 SwiftUI 内部按需更新视图,...最终再次呈现给用户,等待下次界面操作 注意 在 SwiftUI 中,开发者只需要构建一个视图可依赖的数据源,保持数据的单向有序流转即可,其他数据和视图的状态同步问题 SwiftUI 帮你管理,所以 ViewController...,这种视图的拼装方式大大提高了界面开发的灵活性和复用性,视图组件化并任意组合的方式是 SwiftUI 官方非常鼓励的做法。

10.1K20

从用SwiftUI搭建项目说起

这两张图相信看过苹果官方SwiftUI介绍文档并且跟着写了一遍代码的同学应该不陌生,当然我们的目的不是说这两篇的代码,这个具体的可以到下面连接去查看,我自己跟着写了一遍之后对SwiftUI也是有了一个基本的认识...Apple SwiftUI SwiftUI ---- 在进入项目搭建先说说我自己对SwiftUI一个基本的认知: SwiftUI我觉得对iOSer来说最大的是开发UI模式的优化...从 SwiftUI 谈声明式 UI 与类型系统 跨平台: 在最新的swiftUI 5.1中,我们创建一个MultilPlatform App有了下面这些区别: ·Before func...搭建这样一个场景构建一个基本的应用,包括登录和数据处理以及iOS常见控件在SwiftUI中的一些具体的使用,这个项目会随着学习进度慢慢的把所有的内容都基本的补齐,下面是最基本的导航+标签的git效果。...当 @State 装饰过的属性发生了变化,SwiftUI 会根据新的属性值重新创建视图 */ @State private var selectedTab = 0 var

4.4K20

优化在 SwiftUI List 中显示大数据集的响应效率

本文将通过一个优化列表视图的案例,展现在 SwiftUI 中查找问题、解决问题的思路,其中也会对 SwiftUI 视图的显式标识、@FetchRequest 的动态设置、List 的运作机制等内容有所涉及...首先创建一个假设性的需求: 一个可以展示数万条记录的视图 从上个视图进入该视图时不应有明显延迟 可以一键到达数据的顶部或底部且没有响应延迟 响应迟钝的列表视图 通常会考虑采用如下的步骤以实现上面的要求:...NavigationView 进入列表视图 NavigationLink("包含 40000 条数据的列表视图", destination: ListEachRowHasID...找寻问题原因 或许有人会认为,毕竟数据量较大,进入列表视图有一定的延迟是正常的。但即使在 SwiftUI 的效能并非十分优秀的今天,我们仍然可以做到以更小的卡顿进入一个数倍于当面数据量的列表视图。...列表视图的初始化和 body 求值 如果对 SwiftUI 的 NavigationView 有一定了解的话,应该知道 SwiftUI 会对 NavigationLink 的目标视图进行预实例化(但不会对

9.1K20

老人新兵 —— 一款 iOS APP 的开发手记

SwiftUI 给我创建了一个非常高效的环境,在短时间内便可以将整个 app 的原型跑起来,但当真正地将具体实现以及数据流完全串联起来时才发现一切并不那么简单。...最大的一个是如果 view 的内容比较复杂,且 barItem 使用中文或图片,缓慢地从左侧滑动页面返回时,会出现不同 View 顶部的 NavigationBarItem 重叠的现象,导致 BarItem...模拟器中 NavigationLink 只能使用一次,第二次点会失效,实机没有问题。很难实现直接返回到根视图,通过 dissmiss 只能返回到上视图。...导致我无法很好地实现双击 TabView 图标返回该 Tab 的根视图,比较郁闷。...我的 app 中有几处 Sheet 弹出的响应就比较慢( 将 view 移出 sheet,使用 NavigationLink 调用显示就很好 ),尤其是退出时的响应更慢。

2.5K40

Ask Apple 2022 与 SwiftUI 有关的问答(下)

阅读 The SwiftUI Layout Protocol [11]了解如何创建自定义布局。创建从底部开始的滚动视图Q:我如何实现一个在底部对齐的滚动视图,在 macOS 上会不会有糟糕的性能?...navigationDestination,这样侧边栏里的 NavigationLink 就会取代详细栏的根视图。...macOS APIQ:对于运行 Monterey 的 Mac,能否如何在 SwiftUI 中实现下面需求的建议:打开一个窗口在该窗口中初始化数据找到所有打开的窗口确定一个窗口是否打开从不在该窗口的视图中关闭一个窗口...连锁动画Q:在 SwiftUI 中,如何实现连锁动画?例如,我想先给一个视图做动画,当动画完成后立即启动另一个动画。A:不幸的是,目前不可能实现连锁动画。...但这个滚动有两大问题,1、是一个未公开的半成品,有可能会被从 SwiftUI 框架中移除;2、不支持懒加载,即使和 Lazy 视图一起使用也会一次性加载全部的视图

14.7K30

SwiftUI 中创建自适应的程序化导航方案

与 UIKit 使用的命令式导航方式不同,SwiftUI 作为一个声明式框架,感知与设置两者之间是二位一体的关系。读取状态即可获知当前的导航位置,更改状态便可调整导航路径。...在栈中推送和弹出数据的过程对应了导航容器中添加和移除视图的操作。弹出全部数据相当于返回视图,推送多个数据相当于一次性添加多个视图并直接跳转到最后数据所代表的视图。...与 List 进行了深度的绑定对于一个包含三列( A、B、C )的 NavigationSplitView ,我们可以使用任意的方式让这些视图之间产生联动。...比如在本例的 Content 列代码中,为了维持这个限定,只能通过 overlay 来定义占位视图。如果将代码调整成如下样式,则会在转换后丧失程序化导航的能力( 无法通过修改状态,返回上层视图 )。...一次编写便可对应多种设备,这本就是 SwiftUI一个重要特点。尽管仍存在一些不足,但新的导航机制已经在这一方面取得了长足的进步。唯一遗憾的是,仅支持 iOS 16+。希望本文能够对你有所帮助。

4.2K30

SwiftUI 视图的生命周期研究

•在 SwiftUI 生成视图值树时,当发现没有对应的实例时,SwiftUI 会创建一个实例从而获取它的 body 结果。...•在生成新的视图值树时,即使已经有可以对应的实例(该实例并未销毁),SwiftUI 仍可能会创建一个新的实例。...•在 NavigationView 中,如果在 NavigationLink 中使用了静态的目标视图SwiftUI 将会为所有的目标视图创建实例,无论是否访问。...这种情况可能是 SwiftUI 将第一个实例销毁后创建了一个新的实例,也可能是没有销毁第一个实例而直接创建了一个新的实例。...,将完成依赖项的建立工作•在视图的生命周期中,只有一个依赖项副本•在视图的生命周期中,无论创建多少个实例,同一时间只有一个实例可以连接到依赖项•依赖项为视图的 Source of truth 了解 SwiftUI

4.4K30
领券