Swiftui 是什么导致在这段代码中调用updateUIView()?
我知道@State变量的更改会通知@Binding状态已经更改,但是是什么导致调用updateUIView()方法呢?显然,@绑定和调用之间存在某种隐藏的联系,但这是如何工作的呢Swiftui 是什么导致在这段代码中调用updateUIView()?,swiftui,combine,Swiftui,Combine,我知道@State变量的更改会通知@Binding状态已经更改,但是是什么导致调用updateUIView()方法呢?显然,@绑定和调用之间存在某种隐藏的联系,但这是如何工作的呢 // Experiment_Map_View.swift import SwiftUI import MapKit struct Experiment_Map_View: UIViewRepresentable { @Binding var test: Bool func updateUIVie
// Experiment_Map_View.swift
import SwiftUI
import MapKit
struct Experiment_Map_View: UIViewRepresentable {
@Binding var test: Bool
func updateUIView(_ uiView: MKMapView, context: Context) {
print("updateUIView")
print(test)
}
func makeCoordinator() -> Coordinator {
Coordinator(self)
}
final class Coordinator: NSObject, MKMapViewDelegate {
var control: Experiment_Map_View
init(_ control: Experiment_Map_View) {
print("init -----------------")
self.control = control
}
}
func makeUIView(context: Context) -> MKMapView {
print("makeUIView")
let map = MKMapView()
map.delegate = context.coordinator
return map
}
}
struct MyRootView: View {
@State var test: Bool = true
var body: some View {
ZStack {
Experiment_Map_View(test: $test)
VStack {
Spacer()
Button("Next") {
print("Next")
self.test.toggle()
}
}
}
}
}
struct Experiment_Map_View_Previews: PreviewProvider {
static var previews: some View {
MyRootView()
}
}
SwiftUI
正在管理@State
和@Binding
对象的内存,并自动刷新依赖于变量的任何视图的任何UISwiftUI
是封闭源代码的,因此不幸的是,我们还不知道这是如何实现的,但为简单起见,可以将其视为幕后的didSet
修改器 谢谢你,我明白了很多。我希望有人知道“幕后”是如何做到这一点的。这是苹果目前的专有知识。正确答案是答案尚未公开,因为源代码尚未公开。@Lottetororella您知道我的问题的答案吗: