SwiftUI, как добавить пользовательский модификатор с обратным вызовом - PullRequest
0 голосов
/ 09 ноября 2019

В SwiftUI вы можете написать код, подобный следующему:

List {
    ForEach(users, id: \.self) { user in
        Text(user)
    }
    .onDelete(perform: delete)
}

Я пытаюсь добавить функциональность с помощью синтаксического метода .onDelete в мой пользовательский компонент:

struct MyComponen: View {
    @Binding var alert: String

    .
    .
    .
}

Я пытаюсь добавить эту способность с расширением:

extension MyComponent {

   func foo() -> Self { 
        var copy = self
        copy.alert = "Hohoho"
        return copy
    }

    func onDelete() -> Void { 

    }
}

Как я могу изменить состояние (или функцию обратного вызова с):

struct ContentView: View { 
    var body: some View {
        Group {
            MyComponent() //-> with alert = "state 1"
            MyComponent().foo() //-> with alert = "state 2"
            MyComponent().foo(action: actionFunction) //-> how do this?
        }
    } 
}

1 Ответ

1 голос
/ 09 ноября 2019

В продолжение вашего подхода это может выглядеть так, как показано ниже. В качестве альтернативы можно использовать протокол ViewModifier.

struct MyComponen: View {
    @Binding var alert: String
    var action: (() -> Void)?
    var body: some View {
        VStack {
            Text("Alert: \(alert)")
            if nil != action {
                Button(action: action!) {
                    Text("Action")
                }
            }
        }
    }
}

extension MyComponen {

    func foo(perform action: @escaping () -> Void ) -> Self {
         var copy = self
         copy.action = action
         return copy
     }
}

struct TestCustomModifier: View {
    @State var message = "state 2"
    var body: some View {
        VStack {
            MyComponen(alert: .constant("state 1"))
            MyComponen(alert: $message).foo(perform: {
                print(">> got action")
            })
        }
    }
}

struct TestCustomModifier_Previews: PreviewProvider {
    static var previews: some View {
        TestCustomModifier()
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...