【发布时间】:2021-05-18 03:10:04
【问题描述】:
我是 SwiftUI 新手,我一直在尝试如何将 SwiftUI 和 UIKit 集成到同一个应用程序中。我用 SwiftUI 制作了一个简单的登录屏幕。
struct LoginView: View {
var body: some View {
VStack {
LogoView()
InputView(title: "Company Code")
ButtonView(title: "Proceed")
}
}
}
我通过将视图中的所有组件提取到单独的视图(LogoView、InputView、ButtonView)来使它们可重用。
struct LogoView: View {
var body: some View {
VStack {
Image("logo")
Text("Inventory App")
.foregroundColor(.blue)
.fontWeight(.bold)
.font(.system(size: 32))
}
}
}
struct InputView: View {
let title: String
@State private var text: String = ""
var body: some View {
VStack(alignment: .leading) {
Text(title)
.foregroundColor(.gray)
.fontWeight(.medium)
.font(.system(size: 18))
TextField("", text: $text)
.frame(height: 54)
.textFieldStyle(PlainTextFieldStyle())
.padding([.leading, .trailing], 10)
.cornerRadius(10)
.overlay(RoundedRectangle(cornerRadius: 10).stroke(Color.gray))
}
.padding()
}
}
struct ButtonView: View {
let title: String
var body: some View {
Button(title) {
print(#function)
}
.frame(minWidth: 100, idealWidth: 100, maxWidth: .infinity, minHeight: 60, idealHeight: 60)
.font(.system(size: 24, weight: .bold))
.foregroundColor(.white)
.background(Color.blue)
.cornerRadius(10)
.padding([.leading, .trailing])
}
}
我通过将视图嵌入到视图控制器的UIHostingController 中来显示视图。
class LoginViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
let controller = UIHostingController(rootView: LoginView(observable: observable))
controller.view.translatesAutoresizingMaskIntoConstraints = false
addChild(controller)
view.addSubview(controller.view)
controller.didMove(toParent: self)
NSLayoutConstraint.activate([
controller.view.leadingAnchor.constraint(equalTo: view.leadingAnchor),
controller.view.topAnchor.constraint(equalTo: view.topAnchor),
controller.view.trailingAnchor.constraint(equalTo: view.trailingAnchor),
controller.view.bottomAnchor.constraint(equalTo: view.bottomAnchor)
])
}
}
我的问题是如何获取 InputView 中输入的文本,并且按钮点击发生在 ButtonView 中,一直到 View Controller?
在这个tutorial 中,它使用ObservableObject 将数据传回给视图控制器。尽管在该示例中,整个视图都在一个 SwiftUI 文件中。就我而言,我将视图分解为单独的组件。
所以我想知道,ObservableObject 仍然是这样做的方式吗?由于我的视图是子视图,因此我觉得创建多个可观察对象以将值传播到子视图链上并不理想。
有没有更好的方法来实现这一点?
【问题讨论】:
标签: ios swift swiftui observableobject