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

干货 | 关于SwiftUI,看这一篇就够了

SwiftUI的作用。...但是,SwiftUI里面,视图中声明的任何状态、内容和布局,源头一旦发生改变,会自动更新视图,因此,只需要一次布局。属性前面加上@State关键词,即可实现每次数据改动,UI动态更新的效果。...通过@propertyDelegate的修饰,能够解决不同类型的value进行特定的处理;上述包装的方法,能够建立视图与数据之间的关系,并且会判断属性发生变化的情况下,通知SwiftUI刷新视图,编译器能够为...方法重构UI,绘制界面,绘制过程中会自动比较视图中各个属性是否有变化,如果发生变化,便会更新对应的视图,避免全局绘制,资源浪费。...Xcode 11提供了实时预览和静态预览两项功能,实时预览:代码的修改能够实时呈现在Xcode的预览窗口中;此外,Xcdoe还提供了快捷功能,通过command+鼠标点击组件,可以快速、方便地添加组件和设置组件属性

5.8K10

SwiftUI 与 Core Data —— 数据获取

类 Redux 框架通常都建议开发者将整个 app 的状态合成到一个单一的结构实例( State ,符合 Equatable 协议 ),视图通过观察状态的变化( 有些框架支持切片式的观察以改善性能 )...通过新创建一个可以使用 Mock 数据的 FetchRequest ,实现了 SwiftUI 与 Core Data —— 问题[6] 一文中提出的测试、预览模块化的目标。...遗憾的时,NSFetchedResultsController 为 UITableView 准备的基于 NSFetchRequestResultType 优化操作 SwiftUI 并不起作用。...类型引发视图更新的数据发生变化后调用该方法。...不可在 update 方法同步地改变引发视图更新的数据与 SwiftUI 视图更新 Source of truth 的逻辑一致,一个视图更新周期中,不能对 Source of truth 再度更新

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

WWDC 23 之后的 SwiftUI 有哪些新功能

前言 WWDC 23 已经到来,SwiftUI 框架中有很多改变和新增的功能。本文中将主要介绍 SwiftUI 数据流、动画、ScrollView、搜索、新手势等功能的新变化。...也不再需要 @Published 属性包装器,因为 SwiftUI 视图会自动跟踪任何可观察类型的可用属性的更改。...之前的 SwiftUI 框架版本,应该使用 @ObservedObject 属性包装器来订阅更改。现在不需要了,因为 SwiftUI 视图会自动跟踪符合 Observable 协议的类型的更改。...,将可观察类型放入 SwiftUI 环境。...动画 动画始终是 SwiftUI 框架中最重要的部分。 SwiftUI 轻松实现任何动画,但之前的框架版本缺少一些现在具有的功能。

32820

百行代码变十行,苹果SwiftUI可视化编程让开发者惊呼完美

Swift 是苹果于 2014 年发布的全新开发语言,与 Objective-C* 共同运行于 macOS 和 iOS 平台,用于搭建基于苹果平台的应用程序。...只需一次就能定义布局 开发者只需定义视图(view)内容和布局,SwiftUI 懂得什么时候需要改变,并可以随时更新视图)以匹配设计。 ?...当我们设计面板时,我们编辑的所有内容都与左边编辑器的代码完全同步。当我们修改预览(preview)时,对应代码实时生成,也就是说我们对预览修改的内容能实时体现在代码。...Xcode 会立即重新编译你的修改,并将它们插入到 APP 的运行版。因此整个开发预览可视化与代码可编辑性能同时支持并交互。 ?...预览:现在,我们可以创建任何 SwiftUI 视图的一个或多个预览,从而得到样本数据,并配置几乎用户能看到的所有内容,例如大字体、定位或「暗黑模式」等。

4K10

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

SwiftUI 4.0 ,contextMenu 的功能获得了不小的提高。例如一个上下文菜单可以有多个选项、支持 primaryAction、以及定制预览视图。...如果你不想让父视图也被更新,可以创建对象时不使用 @StateObject 或 @ObservedObject 。...场景的内容视图定义了场景创建的窗口中的视图内容,但场景本身定义了应用程序的整体结构。SwiftUI 4.0 ,WindowGroup 获得了相当大的更新,真正具备了开发 macOS 应用的能力。...ViewBuilder 的 if 语句Q:我知道 SwiftUI基于 ResultBuilder 的。所以 if 语句通过树状结构与 buildEither 进行操作。...从父视图通过环境进行传递应该可以满足提问者当前的需求:父视图可以传入新,当前视图也可以视图范围内改变该。总结我忽略掉了没有获得结论的问题。希望上述的整理能够对你有所帮助。

12.2K20

SwiftUI 之 HStack 和 VStack 的切换

前言 SwiftUI 的各种堆栈是许多框架中最基本的布局工具,能够让我们定义组视图,这些组视图可以按照水平、垂直或覆盖视图对齐。...为了观察当前水平方向的尺寸,我们需要用到 SwiftUI 环境系统 — 通过 DynamicStack 声明 @Environment - 标记属性(带有 horizontalSizeClass...关键路径),将会使我们视图内容中切换到当前 sizeClass 的: struct DynamicStack: View { ......使用布局协议 虽然我们最后已经用了非常棒的解决方案,可以在所有支持 SwiftUI 的 iOS 版本中使用,但也让我们来探索一下 iOS 16 引入的一些新的布局工具(写这篇文章时,它作为...就像字面意思一样,这种新的容器将会在我们初始化时传递的候选列表基于当前上下文挑选出最优视图

2.8K10

苹果全新UI框架来了!可视化编程,自动化减少20%代码量

目前TOIBE排名18位: ? RedMond排名11 ? SwiftUI还提供对动态类型、暗黑模式、本地化和访问性的自动支持。 SwiftUI更新了什么?...而SwiftUI通过4种方式,解决了上述问题: 用一个新的声明式UI结构,定义了的布局的外观和工作方式 更新UI预览会自动生成新的Swift代码,反之,更改Swift代码也会更新UI预览 Swift的任何绑定例如有效的...让Xcode for iPad更上一层楼 开发者对Interface Builder的抱怨不是一天两天了,它大大增加了分解视图块以及从视图控制器(view controller)使用视图的工作量,导致出现体积臃肿的视图控制器...感受一下SwiftUI的代码风格 ? Github一个repo整理了WWDC 2019发布的SwiftUI布局框架的一些官方示例: SwiftUI Essentials 创建和组合视图: ?...使用SwiftUI之前要注意的事情 首先,SwiftUI目前只支持10.15 beta以及更新的macOS系统,当然10.15 beta已经是目前最新了。 其次一些可能出现的小问题也是需要注意的。

5.3K20

深度解读 Observation —— SwiftUI 性能提升的新途径

WWDC 2023 ,苹果介绍了 Swift 标准库的新成员:Observation 框架。它的出现有望缓解开发者长期面临的 SwiftUI 视图无效更新问题。...此外, SwiftUI ,引用类型的数据源(Source of Truth)采用了基于 Combine 框架的 ObservableObject 协议实现。...提供属性级别的精确观察,且无需对可观察属性进行特别注解。 减少 SwiftUI 视图的无效更新,提高应用性能。...SwiftUI视图如何观察属性的变化 根据 Observation 框架的工作原理,我们可以推测 SwiftUI 大概会采用下面的方法观察属性与视图更新之间创建联系: struct A:View...SwiftUI 将根据可观察对象视图中的注入方式选择对应的观察手段。 例如,上文中同时满足两种观察途径的可观察对象,根据其注入的方式不同,SwiftUI 采用的更新策略也将不同。

50520

如何在Xcode下预览含有Core Data元素的SwiftUI视图

结合两年来我SwiftUI中使用Core Data的经验和教训,我们将在本文中探讨: •导致SwiftUI预览崩溃的部分原因•如何在之后的开发避免类似的崩溃出现•如何在Xcode安全可靠地预览含有...预览Xcode的工作原理同标准的模拟器十分接近。但为了让它可以即时响应SwiftUI视图的变化,苹果对其做出了不少的修改。...SwiftUI预设了大量同系统有关的环境,通过设置或响应这些数据,我们可以修改系统配置或读取系统信息。 SwiftUI视图采用树状结构组织,在任意节点视图上注入的环境数据都将影响该节点的所有子视图。...SwiftUI提供的managedObjectContext环境视图中使用或操作Core Data元素提供了基础和便利。...不过我们CoreDataStack创建的基于内存的持久化存储仍然是Sqlite类型。是将数据文件保存在/dev/null的Sqlite类型。

5.1K10

SwiftUI 状态管理系统指南

SwiftUI没有使用委托、数据源或任何其他UIKit和AppKit等命令式框架中常见的状态管理模式,而是配备了一些属性包装器[1],使我们能够准确地声明我们的数据如何被我们的视图观察、渲染和改变。...观察对象 State和Bingding的共同点是,它们处理的是SwiftUI视图层次结构本身管理的。...作为一个例子,让我们更新上面定义的ProfileView——通过将管理User模型的责任从视图本身转移到一个新的、专门的对象。...观察和修改环境变量 最后,让我们来看看SwiftUI的环境系统如何被用来两个互不直接连接的视图之间传递各种状态。...尽管一个父视图和它的一个子视图之间创建绑定通常很容易,但在整个视图层次结构传递某个对象或可能相当麻烦——而这正是环境变量旨在解决的问题类型。 有两种主要的方法来使用SwiftUI的环境。

5K20

SwiftUI 与 Core Data —— 数据定义

遗憾的是,托管对象对于以类型为主的 SwiftUI 来说并不算友好,因此,不少开发者都会在视图中将托管对象实例转换成一个结构体实例以方便接下来的操作( 如何在 Xcode 下预览含有 Core Data...这个类型除了用于为 SwiftUI视图提供数据外,同时也会被用于为其他的数据流提供有效信息,例如,类 Redux 框架,通过 Action 为 Reducer 提供所需数据。...如果没有 AnyConvertibleValueObservableObject ,开发者仅能对应用的部分视图进行预览不创建托管环境的情况下 ),而通过 AnyConvertibleValueObservableObject...通过结合之后介绍的与 Core Data 数据操作进行解耦的方法,无需编写任何 Core Data 代码,就可以实现完成应用中所有视图和数据操作逻辑代码的目标。而且全程预览交互,测试。...Core Data 元素的 SwiftUI 视图: https://www.fatbobman.com/posts/coreDataInPreview/#为_SwiftUI_预览提供_Core_Data

2.4K40

WWDC - SwiftUI - 初恋般的感觉

你可以通过Xcode新的实时反馈功能,来优化你的视图布局 。 第一节 创建一个使用SwiftUI的新Xcode项目。浏览画布、预览SwiftUI模板代码。...要在Xcode预览画布上的视图并与之交互,请确保您的Mac运行的是macOS 10.15 beta版。 macOS 10.15 beta版下载地址 Xcode 11下载地址 ?...当你修改文案后,SwiftUI会自动更新视图。 ? 自定义Text View 你有两种方式来自定义TextView。...你可以MapKit的MKMapView类来展示渲染地图界面。 SwiftUI要使用UIView或者其子类,你需要让你的view遵循UIViewRepresentable协议。...第四步 点击Live Preview来预览效果。 预览状态下,你可以继续编写view的代码,Live Preview会实时更新视图。 第五步 将CircleImage添加到stack上面。

3.8K10

StateObject 与 ObservedObject

StateObject 是 SwiftUI 2.0 才添加的属性包装器,它的出现解决了某些情况下使用 ObservedObject 视图会出现超预期的问题。...会驱动其所属的视图进行更新。...基于 Swift 的 ARC( 自动引用计数 )机制,StateObject 保证了可观察对象的生存期必定不小于视图的存续期,从而确保了视图的存续期内数据的稳定。...视图的生存期从其被加载到视图树时开始,至其被从视图树上移走结束。视图的存续期中,视图将根据 source of truth ( 各种依赖源 )的变化而不断变化。... @StateObject 研究[4] 一文,展示了因错误使用 ObservedObject 而引发灵异现象的代码片段出现这种情况是因为一旦,视图的存续期中,SwiftUI 创建了新的实例并使用了该实例

2.4K20

Airbnb 的三阶段 SwiftUI 迁移实践

第一阶段,他们基于现有的设计系统构建一系列重用的组件。第二阶段,他们对基本组件进行组合,构建出整个屏幕。第三个也是最后一个阶段,屏幕将被组合成完整的功能。...第二步是构建基础设施,实现基于 UIKit 的 Epoxy 视图SwiftUI 视图之间的双向桥接。桥接的实现细节可以原文中找到。...简单地说,桥接是基于 UIHostingViewController(将 SwiftUI 层次结构嵌入到视图控制器)和 UIViewRepresentable(将 UIKit 视图集成到 SwiftUI...测试性 Airbnb 有比较高的优先级。他们的新 SwiftUI 实现需要能够很好地适应他们的快照测试方法。...为此,他们为每个定义的视图变体起了一个名字,以便与他们的快照测试服务一起使用,并让所有视图变体遵循 Xcode 的 PreviewProvider 协议,以便使用 Xcode 预览

19710

SwiftUI - 百行代码变十行,Swift再创辉煌

而对于开发者来说,新发布的 SwiftUI 可能是最吸引人的特性, 苹果公司软件工程高级副总裁Craig Federighi的演示,我们可以轻松地把一百行的前端代码缩减到十几行。...通过 SwiftUI,开发者轻松地将动画添加到几乎任何控件。...当在设计工具工作时,所编辑的内容会立刻反映到代码上,如果从模拟器切换到手机,手机也能立马看到预览效果。 ?...// SwiftUI 示例代码 // 为视图的任何状态声明内容和布局。SwiftUI知道该状态何时发生变化,并更新视图的呈现以匹配该状态。...构建复用的组件 将小的、单一职责的视图组合成更大、更复杂的接口。在为任何苹果平台设计的应用程序之间共享自定义视图

3K40

架构之路 (七) —— iOS App的SOLID原则(一)

开始 首先看下主要内容: SOLID 是一组原则,引导您编写清晰有序的代码,而无需额外的努力。 了解如何将其应用于您的 SwiftUI iOS 应用程序。内容来自翻译。...本教程,您将: 学习 SOLID 的五个原则。 审计一个没有遵循他们的工作项目。 更新项目,看看 SOLID 有多大的不同。...你需要内存存储来 SwiftUI 预览显示虚假数据。...对于 SwiftUI 预览,您将始终显示日常开支。 只需更改数据源类型,您就可以使视图更加通用。 这显示了这两个文件中有多少代码重复。 现在,即使您创建了一般视图,您仍然没有在任何地方使用它。...3) 添加新报告类型是枚举添加新的问题。 4) 创建预览和测试比以前容易得多,而且您不再需要任何复杂的模拟对象。 项目开始之前的情况和现在的情况之间有很大的改进。

4.7K10

构建稳定的预览视图 —— SwiftUI 预览的工作原理

欢迎大家 Discord 频道[2] 中进行更多地交流 让预览崩溃的一段视图代码 不久前,Toomas Vahter 写了一篇博客 Bizarre error in SwiftUI preview[3...接下来,让我们继续查看 Xcode 是如何加载预览视图的。。 项目的 Derived Data 目录查找尾缀为 .preview-thunk.dylib 的文件。...通过 XPC 预览进程与 Xcode 之间进行通信,最终实现了 Xcode 预览特定视图的目的。...通过 XPC 发送消息指令, _XCPreviewKit 框架更新预览窗口,并在两个线程建进行交互与同步 用户 Xcode 界面中看到预览效果 从预览的实现可以得到的部分结论 如果项目无法编译,预览也无法正常运行...但是,这也可能导致无法正常编译的情况发生(例如本文中的例子) 预览是以预览衍生文件作为入口的,开发者必须在预览代码预览视图提供足够的上下文信息( 例如注入所需的环境对象 ) 总的来说,Xcode 预览功能虽然视图开发流程中极为方便

48310
领券