SwiftUI 简明教程之属性包装器
本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容。
Eul 是一款 SwiftUI & Combine 教程 App(iOS、macOS),以文章(文字、图片、代码)配合真机示例(Xcode 12+、iOS 14+,macOS 11+)的形式呈现给读者。笔者意在尽可能使用简洁明了的语言阐述 SwiftUI & Combine 相关的知识,使读者能快速掌握并在 iOS 开发中实践。
常用属性包装器
SwiftUI 提供了许多的属性包装器(Property Wrapper),极大简化了我们的工作。属性包装器,实际上是对声明的属性做了一层封装,在内部实现了一些我们看不见的操作。
下面会在概念和使用上简介 SwiftUI 中常用的属性包装器,不在代码层面做具体演示。更详细的内容可以参见我的两篇文章:
@State
在当前 View 中声明,通常使用 private 修饰,当修饰的属性值改变时,界面会随之更新。
@Binding
接收从外部对象传入的绑定值,同时可以将属性的变化回传给外部对象,即数据是双向绑定的。如 A 的属性 @State private var value: String 传入 B 的属性 @Binding var value: String ,当 B 中的 value 值改变时, A 的 value 也会更新。
@Environment
访问预设的环境变量,如系统的暗黑模式、时区等。
@ObservedObject、@Published
@ObservedObject 可以修饰遵循 ObservableObject 协议的 class 对象,该对象实例中的属性可以使用 @Published 修饰。当使用 @Published 修饰的属性值发生改变时,所有使用 @ObservedObject 修饰的对象实例,都会更新相应的值,通常用于在多个界面之间同步数据和状态。
@StateObject
与 @ObservedObject 一样,@StateObject 修饰的对象同样是遵循 ObservableObject 协议的 class 对象。但是区别在于,@StateObject 修饰的对象只会在所属的 View 中创建一次并在 View 的生命周期内存储相应的状态,而 @ObservedObject 修饰的对象会随着 View 的重绘生成新的对象,不会在 View 的生命周期内存储该对象的状态。
@EnvironmentObject
@EnvironmentObject 修饰的对象同样需要遵循 ObservableObject 协议,与 @ObservedObject 功能类似,但是它有着更强大的功能,子视图可以直接获取父视图注入的环境变量。比如,我们有视图 A、B、C,A 包含 B,B 包含 C,如果我们使用 @ObservedObject 来传递变量,需要从 A 传入 B,再从 B 传入 C,C 才能获取到对应的变量。而 @EnvironmentObject 无需如此繁琐,我们直接通过父视图 A 注入环境变量,视图 C 就可以获取注入的变量,省去中间的传递过程。
@AppStorage
等同于 Userdefaults。
@SceneStorage
用于多窗口模式,相当于为每个场景持久化了一个场景值,每个场景只能读取该场景持久化的值。当场景销毁时,该值也会销毁。建议存储轻量的、不敏感的数据
@UIApplicationDelegateAdaptor
用来调用 AppDelegate 中的生命周期方法。
自定义属性包装器
使用属性包装器可以使我们的代码精简,那么如何根据需求自定义呢?
自定义的属性包装器需要使用 @propertyWrapper 声明,并且必须有一个名为 wrappedValue 的属性。例如下面的代码,通过 CNNumber 这样一个属性包装器,可以将字符串中的阿拉伯数字转化成中文数字:
@propertyWrapper
struct CNNumber {
private let table = [
"0" : "〇",
"1" : "一",
"2" : "二",
"3" : "三",
"4" : "四",
"5" : "五",
"6" : "六",
"7" : "七",
"8" : "八",
"9" : "九",
]
private var value = ""
var wrappedValue: String {
get { value }
set { value = convertToCNNumbers(newValue) }
}
init(wrappedValue: String) {
self.wrappedValue = wrappedValue
}
func convertToCNNumbers(_ string: String) -> String {
var res = ""
for v in string {
res += table[String(v)] ?? ""
}
return res
}
}
然后我们定义一个 Person 结构体,使用 CNNumber 去修饰 birth 属性,调用时正如示例所示,它被转换成了中文数字。
struct Person {
var name: String
@CNNumber var birth: String
}
struct ContentView: View {
private let p = Person(name: "Steve Jobs", birth: "1955年2月24日")
var body: some View {
Text(p.birth)
}
}
本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容。
SwiftUI 简明教程之属性包装器的更多相关文章
- SwiftUI 中一些和响应式状态有关的属性包装器的用途
SwiftUI 借鉴了 React 等 UI 框架的概念,通过 state 的变化,对 View 进行响应式的渲染.主要通过 @State, @StateObject, @ObservedObject ...
- SwiftUI 简明教程之指示器
本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容. Eul 是一款 SwiftUI & Combine 教程 App(iOS.macOS),以文章(文字.图片. ...
- SwiftUI 简明教程之自定义 Modifier
本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容. Eul 是一款 SwiftUI & Combine 教程 App(iOS.macOS),以文章(文字.图片. ...
- SwiftUI 简明教程之文本与图片
本文为 Eul 样章,如果您喜欢,请移步 AppStore/Eul 查看更多内容. Eul 是一款 SwiftUI & Combine 教程类 App(iOS.macOS),以文章(文字.图片 ...
- Python 简明教程 --- 22,Python 闭包与装饰器
微信公众号:码农充电站pro 个人主页:https://codeshellme.github.io 当你选择了一种语言,意味着你还选择了一组技术.一个社区. 目录 本节我们来介绍闭包与装饰器. 闭包与 ...
- ArcGIS Pro 简明教程(4)工具和模型构建器
ArcGIS Pro 简明教程(4)工具和模型构建器 by 李远祥 工具箱中的工具 ArcGIS Pro 在1.3版本基本上已经继承了ArcMap的所有工具,而且会不断加入一些它自身才有的工具,例如适 ...
- Python 简明教程 --- 20,Python 类中的属性与方法
微信公众号:码农充电站pro 个人主页:https://codeshellme.github.io 与客户保持良好的关系可以使生产率加倍. -- Larry Bernstain 目录 类中的变量称为属 ...
- grootjs 简明教程
grootJs简明教程 mvvm框架也是解决的一类问题,在某些时候会提高生产效率: 经过接近一个月的努力,grootJs测试版终于发布了 grootJs是一个mvvm的框架,名字取 grass 和ro ...
- Lisp简明教程
此教程是我花了一点时间和功夫整理出来的,希望能够帮到喜欢Lisp(Common Lisp)的朋友们.本人排版很烂还望多多海涵! <Lisp简明教程>PDF格式下载 <Lisp简明教程 ...
随机推荐
- 微信开发者工具导入 wepy 项目“app.json 未找到”报错解决方法
版本信息: 微信开发者工具:1.03.2101150 wepy:2.0 wepy/cli:6.14.8 问题描述 按照 wepy 文档中的步骤新建项目: $ npm install @wepy/cli ...
- 学一手,知乎大V(轮子哥)当年靠它进微软亚洲研究院
前言 vczh本名陈梓瀚,不过大家更愿意叫他「轮子哥」,毕业于华南理工大学软件学院.vczh大学时代就在微软实习,毕业后即加入微软.开始时是在微软上海,后来进入北京的微软亚洲研究院.现已移居美国西雅图 ...
- 学习笔记-json数据格式化
标准的json : let result=[{"a": 'aa', "b": 'aa', "c": 'aa'}, {"a" ...
- 将Java编译为本地代码
将Java编译为本地代码 通常Java程序的执行流程为:将Java代码编译为Byte Code(字节码),然后JVM执行引擎执行编译好的Byte Code.这是一种中间语言的特性,它的好处就是可以做到 ...
- 翻译:《实用的Python编程》07_04_Function_decorators
目录 | 上一节 (7.3 返回函数) | 下一节 (7.5 装饰方法) 7.4 函数装饰器 本节介绍装饰器(decorator).因为这是一个高级主题,所以我们只做简单介绍. 译注:根据译者个人的猜 ...
- 【图像处理】OpenCV+Python图像处理入门教程(七)图像形态学操作
图像形态学主要从图像内提取分量信息,该分量信息通常对表达图像的特征具有重要意义.例如,在车牌号码识别中,能够使用形态学计算其重要特征信息,在进行识别时,只需对这些特征信息运算即可.图像形态学在目标视觉 ...
- CPF 入门教程 - 控件布局(六)
CPF netcore跨平台桌面UI框架 系列教程 CPF 入门教程(一) CPF 入门教程 - 数据绑定和命令绑定(二) CPF 入门教程 - 样式和动画(三) CPF 入门教程 - 绘图(四) C ...
- 漫谈SCA(软件成分分析)测试技术:原理、工具与准确性
摘要:本文介绍了SCA技术的基本原理.应用场景,业界TOP SCA商用工具的分析说明以及技术发展趋势:让读者对SCA技术有一个基本初步的了解,能更好的准确的应用SCA工具来发现应用软件中一些安全问题, ...
- Fastjson反序列化漏洞复现
Fastjson反序列化漏洞复现 0x00 前言 对Fastjson反序列化漏洞进行复现. 0x01 漏洞环境 靶机环境:vulhub-fastjson-1.2.24 ip:172.16.10.18 ...
- hdu2276 矩阵构造
题意: 给了n个灯泡的状态,他们绕成一个环,0是灭,1是亮,每一秒灯泡的状态都会改变,规则是如果当前这个灯泡的左边的灯泡当前是状态1,那么下一秒当前的这个灯泡状态就改变0变1,1变0,最后问 ...