Цепные методы с подклассом UIViewRepresentable - PullRequest
0 голосов
/ 15 марта 2020

Я пытаюсь реализовать UITextView, используя следующее UIViewRepresentable

import Foundation
import SwiftUI

struct TextView: UIViewRepresentable {
    @Binding var text: String
    var _editable : Bool = true

    func makeUIView(context: Context) -> UITextView {
        let result = UITextView()
        let font = UIFont(name: "Menlo",size: 18)
        result.font = font

        return result
    }

    func updateUIView(_ uiView: UITextView, context: Context) {
        uiView.text = text
        uiView.isEditable = _editable
    }

    mutating func editable(_ editable: Bool) -> TextView {
        _editable = editable
        return self
    }
}

Вы заметите мутирующее веселье c editable, которое я хотел бы использовать в моей структуре SwiftUI, как это :

        return ZStack(alignment: Alignment.trailing) {
            TextView(text: Binding($note.content)!)
                .editable(true) // <<<< Here
            VStack {
                Text(dateString)
                    .font(.caption)
                    .foregroundColor(Color.gray)
                    .padding(3)
                Spacer()
            }
        }

Но выдается следующее исключение:

Cannot use mutating member on immutable value: function call returns immutable value

Screenshot

Я подозреваю, что UIViewRepresentable не изменчивый, и интересно, есть ли способ обойти это

1 Ответ

0 голосов
/ 16 марта 2020

Эти «цепочечные методы» не должны изменяться. Если вы посмотрите на методы, которые вы можете объединить в цепочке SwiftUI, ни один из них не помечен mutating. Быстрый пример .

Эти методы должны возвращать новый экземпляр структуры с некоторым измененным свойством .

, например, так:

func editable(_ editable: Bool) -> TextView {
    // This is a new instance of the struct, but _editable is changed to the new value
    TextView(text: $text, _editable: editable) 
}
...