下面是一个简单的例子。您可以创建新的SwiftUI iOS项目并将其复制到ContentView文件中。
import SwiftUI
struct Settings {
static let onOff = "onOff"
}
struct ContentView: View {
@AppStorage(wrappedValue: false, Settings.onOff) var onOff
var body: some View {
NavigationView {
GeometryReader { reader in // < Comment out this line
List {
Section (header:
VStack {
HStack {
Spacer()
VStack {
Text("THIS SHOULD BE FULL-WIDTH")
Text("It is thanks to GeometryReader")
}
Spacer()
}
.padding()
.background(Color.yellow)
HStack {
Text("This should update from AppStorage: ")
Spacer()
Text(onOff == true ? "ON" : "OFF")
}
.padding()
}
.frame(width: reader.size.width) // < Comment out this line
.textCase(nil)
.font(.body)
) {
Toggle(isOn: $onOff) {
Text("ON / OFF")
}
}
}
.listStyle(GroupedListStyle())
} // < Comment out this line
}
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
}
}我有三个要素:
AppStorage只有在没有GeometryReader的情况下才能完美地工作。请注释掉3行标签来检查它。
是虫子吗?或者我的AppStorage代码出了什么问题?或者GeometryReader部分是错的?如果我可以设置黄色部分的全宽度,我可以完全放弃GeometryReader .
发布于 2021-09-06 16:31:05
在我的测试中起作用的一个解决方案是分解GeometryReader的内容,包括@AppStorage。
struct ContentView: View {
var body: some View {
NavigationView {
GeometryReader { proxy in
_ContentView(width: proxy.size.width)
}
}
}
}
struct _ContentView: View {
var width: CGFloat
@AppStorage(wrappedValue: false, Settings.onOff) var onOff
var body: some View {
List {
Section(header: header) {
Toggle(isOn: $onOff) {
Text("ON / OFF")
}
}
}
.listStyle(GroupedListStyle())
}
var header: some View {
VStack {
VStack {
Text("THIS SHOULD BE FULL-WIDTH")
Text("It is thanks to GeometryReader")
}
.padding()
.frame(width: width)
.background(Color.yellow)
HStack {
Text("This should update from AppStorage: ")
Spacer()
Text(onOff == true ? "ON" : "OFF")
}
.padding()
}
.textCase(nil)
.font(.body)
}
}发布于 2021-09-06 12:05:39
是的,这绝对是个窃听器。看起来,由于某些原因,AppStorage与State的行为不完全相同,而且更改不会触发GeometryReader内部的更新。示例可以简化为:
struct ContentView: View {
@AppStorage("onOff") var onOff = false
var body: some View {
VStack {
Text("Text updating: " + (onOff == true ? "ON" : "OFF"))
GeometryReader { reader in
Toggle(isOn: $onOff) {
Text("Text not updating: " + (onOff == true ? "ON" : "OFF"))
}
}
}
}
}这在最新的iOS 15测试版中甚至没有得到修正。您可以尝试使用一些重复的状态变量进行黑客攻击,但是我建议您切换到自定义AppStorage,它在这种情况下工作得很好。
https://stackoverflow.com/questions/69073841
复制相似问题