将数据从 SwiftUI 传递到 UIKit 的回调

Deg*_*sei 3 uikit ios swift swiftui

如何在回调的闭包中将数据从 SwiftUI 视图发送到 UIKit ViewController?假设我们有 SwiftUI 视图:

import SwiftUI

struct MyView: View {
    var buttonPressed: (() -> Void)?
    @State var someData = ""
    
    var body: some View {
        ZStack {
            Color.purple
            Button(action: {
                someData = "new Data"
                self.buttonPressed?()
                
            }) {
                Text("Button")
            }
        }
    }
}

struct MyView_Previews: PreviewProvider {
    static var previews: some View {
        MyView()
    }
}
Run Code Online (Sandbox Code Playgroud)

还有 ViewController,里面有 SwiftUI 视图:

import UIKit
import SwiftUI

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view.
        
        let swiftUIView = MyView()
        let hostingViewController = UIHostingController(rootView: swiftUIView)
        self.view.addSubview(hostingViewController.view)
        
        hostingViewController.view.translatesAutoresizingMaskIntoConstraints = false
        hostingViewController.view.topAnchor.constraint(equalTo: self.view.topAnchor).isActive = true
        hostingViewController.view.bottomAnchor.constraint(equalTo: self.view.bottomAnchor).isActive = true
        hostingViewController.view.leftAnchor.constraint(equalTo: self.view.leftAnchor).isActive = true
        hostingViewController.view.rightAnchor.constraint(equalTo: self.view.rightAnchor).isActive = true
        
        hostingViewController.rootView.buttonPressed = {
            print ("callback recived")
            // i know i can try to get the data in this way, but if MyView become too complex than it won't look well
            //print(hostingViewController.rootView.$someData)
        }

    }
}
Run Code Online (Sandbox Code Playgroud)

如何通过闭包将 someData 发送到 ViewController?

Asp*_*eri 5

您可以通过参数传递它,例如

struct MyView: View {
    var buttonPressed: ((String) -> Void)? // << here !!
    @State var someData = ""
    
    var body: some View {
        ZStack {
            Color.purple
            Button(action: {
                someData = "new Data"
                self.buttonPressed?(someData)  // << here !!
Run Code Online (Sandbox Code Playgroud)

    hostingViewController.rootView.buttonPressed = { value in // << here !!
        print("callback received")
        print(value)
    }
Run Code Online (Sandbox Code Playgroud)