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

SwiftUI 4.0 的全新导航系统

欢迎大家在 Discord 频道[2] 中进行更多地交流 长久以来,开发者对 SwiftUI导航系统颇有微词。...SwiftUI 4.0( iOS 16+ 、macOS 13+ )对导航系统作出了重大改变,提供了以视图堆栈为管理对象的新 API ,让开发者可以轻松实现编程式导航。本文将对新的导航系统作以介绍。...NavigationLink("SubView3",value: 3) NavigationLink("SubView4", destination: { SubView4() }) // 不要在编程式导航中混用声明式导航...4.0 之前的版本上使用类似的功能,可以参考我在 用 NavigationViewKit 增强 SwiftUI导航视图[4] 一文中的实现方法 其他增强 除了上述的功能, 新的导航系统还在很多其他的地方也进行了增强...下对 iPad 进行适配: https://www.fatbobman.com/posts/swiftui-ipad/ [4] 用 NavigationViewKit 增强 SwiftUI导航视图

10.2K62

用NavigationViewKit增强SwiftUI导航视图

用NavigationViewKit增强SwiftUI导航视图 如果想获得更好的阅读体验,请访问我的博客 www.fatbobman.com[1] 最近一直在为我的iOS健康管理app健康笔记3.0[...由于SwiftUI原生提供的导航手段能力有限,因此在之前的版本中,NavigationView总是使用的不是那么的顺手。...该扩展遵循以下几个原则: •非破坏性任何新添加的功能都不能影响当前SwiftUI提供的原生功能,尤其是不能影响例如Toolbar、NavigationLink在NavigationView中的表现•尽可能便于使用仅需极少的代码便可使用新增功能...,鱼和熊掌不可兼得•使用程序化的NavigationLink通过撤销根视图的程序化的NavigationLink(通常是isActive)来返回。...,因此需要为每个受管理的导航视图进行注册。

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

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

这两个错误包括:通过手势取消 Sheet 后,快速右滑导航容器导致应用锁死;以及在滚动中返回上层视图时导致应用崩溃。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...如果我们认为问题出在这里,就需要使用编程式导航的方式来调整代码。为了不影响用户的使用习惯,我们禁用了 NavigationStack 自带的 Back 按钮。...在我们遇到问题的两个场景中,应用程序都恰好使用了导航容器,并且通过特定的操作,使 RunLoop 处于了适合 AG 打包更新的状态。...总结今年 SwiftUI 已经进入了第五个年头。随着版本的提高,SwiftUI 的功能也确实得到了相当程度的增加。

603110

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

这两个错误包括:通过手势取消 Sheet 后,快速右滑导航容器导致应用锁死;以及在滚动中返回上层视图时导致应用崩溃。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死 这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...如果我们认为问题出在这里,就需要使用编程式导航的方式来调整代码。 为了不影响用户的使用习惯,我们禁用了 NavigationStack 自带的 Back 按钮。...在我们遇到问题的两个场景中,应用程序都恰好使用了导航容器,并且通过特定的操作,使 RunLoop 处于了适合 AG 打包更新的状态。...总结 今年 SwiftUI 已经进入了第五个年头。随着版本的提高,SwiftUI 的功能也确实得到了相当程度的增加。

28320

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

从 4.0 版本开始,苹果对之前 SwiftUI 有限的程序化导航能力进行了大幅度的增强,通过引入 NavigationStack 和 NavigationSplitView,开发者基本上具备了全程掌握应用的导航状态的能力...与 UIKit 使用的命令式导航方式不同,SwiftUI 作为一个声明式框架,感知与设置两者之间是二位一体的关系。读取状态即可获知当前的导航位置,更改状态便可调整导航路径。...因此在 SwiftUI 中,掌握两种导航容器的状态表述差异是实现自适应导航方案的关键。...Text("RootID:\(info.rootID)") Text("Current Level:\(info.level)") NavigationLink...本着“一案一议”的原则,当前方案可以实现对任意的导航逻辑进行转换。总结可以在 此处[5] 获取本文的全部代码。一次编写便可对应多种设备,这本就是 SwiftUI 的一个重要特点。

4.2K30

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

是否有任何建议用来检测列表中的行选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 或从列表中选择一个选项 )?...在常规宽度下,我们在详细视图中有一个带有导航堆栈的侧边栏。在紧凑宽度下,我们有一个标签栏,每个标签都有一个导航堆栈。...A:目前最好的方法是建立一个导航状态模型对象,它持有导航状态的规范表示,它可以为你的正常和紧凑显示提供专门的程序绑定。...阅读 SwiftUI 4.0 的全新导航系统[13] ,了解它们之间的不同。位置偏移的方法与效率Q:在非线性位置( 有 2 个轴 )渲染带有圆形图像最好方法是什么?...A:紧凑( compact )确实对应于一个折叠的导航分割视图。如何改善一个包含大量 UITextField 的视图效率Q:我有一个包含 132 个 UITextField 的 SwiftUI 视图。

12.2K20

掌握 SwiftUI 的 Safe Area

掌握 SwiftUI 的 Safe Area 访问我的博客 www.fatbobman.com[1] 可以获得更好的阅读体验 Safe Area(安全区域)是指不与导航栏、标签栏、工具栏或其他视图控制器提供的视图重叠的内容空间...SwiftUI 同时提供了一些方法和工具让开发者对安全区域有所控制。 本文将探讨如何在 SwiftUI 中获取 SafeAreaInsets、将视图绘制到安全区域之外、修改视图的安全区域等内容。...对于根视图来说,safeAreaInsets 反映的是状态栏、导航栏、主页提示器以及 TabBar 等在各个边的占用数值。...edges: .bottom) // 扩展到顶部和底部.ignoresSafeArea(edges: [.bottom, .trailing]) // 横向扩展.ignoresSafeArea(edges:.horizontal....tint(.green) } .padding(.horizontal

7.5K31

肘子的 Swift 周报 #031 |苹果用 M4 来展现拥抱 AI 的决心

How to train your first machine learning model and run it inside your iOS app via CoreML( 如何通过 CoreML...本教程详细介绍了如何从零开始构建一个名为 “SyncUps” 的复杂 SwiftUI 应用,涵盖了如使用值类型模型化领域、从状态驱动导航、简化领域模型、控制依赖关系以及深入测试应用逻辑等多个核心原则。...团队面临的主要问题包括:与 SwiftUI 和现代 Swift 包的兼容性问题、Xcode SwiftUI 预览功能中断、storyboards 加载缓慢、以及 Podfile 复杂性增加和依赖维护困难等...id=40262897 [8] How to train your first machine learning model and run it inside your iOS app via CoreML...应用中训练并运行你的第一个机器学习模型 ): https://krausefx.com/blog/how-to-train-your-first-machine-learning-model-and-run-it-inside-your-ios-app-via-coreml

13910

鸿蒙应用开发-初见:ArkUI

.padding(.leading, 2) } } .padding(.vertical, 16) .padding(.horizontal...Spacer()}.frame(height: 116).background(.white).clipShape(RoundedRectangle(cornerRadius: 8)).padding(.horizontal...想了解更多Flutter的布局原理可以查看 深入理解 Flutter 布局约束 SwiftUI中的View布局原理参考SwiftUI中的布局原理可以参考下图。...想了解细节,可参考 SwiftUI 中布局的工作原理小结声明式布局想要布局子视图都会经历由上到下的一个过程,只有知道了子视图的大小之后才能根据对齐方式将子视图放置在准确的位置。...DataPanel 数据面板组件,使用占比图展示多个数据的占比情况Gauge 以环形图表形式展示数据Marquee 走马灯效果PatternLock 图形密码锁组件Rating 评分组件Stepper 步骤导航器组件

12310

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券