在需要@Binding的地方传递@Published(SwiftUI,Combine)

问题描述 投票:0回答:1

一个

ViewModel
类有一个
sourceProperty
正在由
TextField
编辑。该属性是
@Published
。我想将它传递给
Logic
类,该类具有带有
Binding<String>
的初始化程序。该类将监听
sourceProperty
更改,对其做出反应并将其输出设置为
@Published output
属性。

如何将

@Published sourceProperty
作为初始化参数传递给
Logic
类?

相关代码:

final class ViewModel {
    @Published var sourceProperty: String = ""
    private var logic: Logic?

    init() {
        self.logic = Logic(data: $sourceProperty)
        $logic.output.sink({result in 
            print("got result: \(result)")
        })
    }

}

final class Logic: ObservableObject {
    private var bag = Set<AnyCancellable>()
    @Published var output: String = ""
    @Binding var data: String
    init(data: Binding<String>) {
        self._data = data

        $data.sink({ newValue in 
            output = newvalue + "ABCDE"
        }).store(in: &bag)
    }
}

到目前为止,我收到以下错误:

无法将“Published.Publisher”类型的值转换为预期值 参数类型“绑定”

目标是使用对象自身属性的更改来触发另一个对象中的方法调用,然后将该第二个对象的输出绑定到某个视图。

视图层:

public struct ViewLayer: View {
    @Binding private var sourceProperty: String

    public init(_ placeholder: String,
                sourceProperty: Binding<String>,
    ) {
        self.placeholder = placeholder
        self._sourceProperty = sourceProperty
    }

    public var body: some View {
        TextField(placeholder, text: $sourceProperty)
    }

 }
swift swiftui binding combine publisher
1个回答
10
投票

如果我正确理解你的问题,你可能正在寻找类似的东西:

final class ViewModel: ObservableObject {
    
    @Published var sourceProperty: String = ""
    private lazy var logic = Logic(data: $sourceProperty)
    private var cancellable: AnyCancellable?

    init() {
        cancellable = logic.$output
            .sink { result in
                print("got result: \(result)")
            }
    }

}

final class Logic: ObservableObject {
    
    @Published private(set) var output: String = ""
    
    init(data: Published<String>.Publisher) {
        data
            .map { $0 + "ABCDE" }
            .assign(to: &$output)
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.