SwiftUI View и Swift Package Manager - PullRequest
       42

SwiftUI View и Swift Package Manager

1 голос
/ 08 января 2020

Я пытаюсь создать пакет Swift, который по сути является одним представлением SwiftUI. Я создал образец здесь, чтобы показать, что происходит. То, что делает упакованный, не имеет значения, я только что включил некоторые переменные @State и @Binding в представление, чтобы получить ту же ошибку, что и в моем реальном пакете. Структура представления выглядит следующим образом.

import SwiftUI

public struct SampleView: View {
    @Binding var myNum:Int
    @State var fixedText:String = ""
    var myText = ""
    var optional: String?


   public  var body: some View {
        VStack {
            if optional != nil {
                Text(optional!)
            }
            Text(myText)
            Text("Parent number: \(myNum)")
            Text("\(fixedText)")
            Button("Increment num") {
                self.myNum += 1
            }.foregroundColor(.blue)
            Button("Change Parent Text") {
                self.fixedText = "Only Changes Child"
            }.foregroundColor(.blue)
        }.background(Color.red)
            .foregroundColor(.white)
    }
}

Когда я добавляю пакет и импортирую его в одно из представлений в моем проекте, я должен иметь возможность использовать «Сделать что-то подобное» так же, как я могу, если представление - это не входит в пакет Swift:

 SampleView(myNum: $myNum,
             fixedText: parentText,
             myText: "Display Text Passed from parent")

Однако я не получаю завершения кода и получаю сообщение об ошибке:

'SampleView' initializer is inaccessible due to 'internal' protection level

Я пробовал все виды инициализации в структуре SampeView, но продолжайте получать всевозможные ошибки. Я просто не понимаю, как исправить уровни доступа здесь. Кто-нибудь может помочь? Скриншот здесь тоже. enter image description here

1 Ответ

1 голос
/ 08 января 2020

Здесь ожидается объявление в пакете (протестировано с Xcode 11.2.1 / iOS 13.2.2). Обратите внимание, что @State не разрешено использовать за пределами View, поэтому все, что вам нужно сделать в синхронизации c, должно быть передано через Binding:

public struct SampleView: View {
    @Binding var myNum:Int
    @Binding var fixedText:String
    var myText: String
    var optional: String?

    public init(myNum: Binding<Int>, fixedText: Binding<String>, 
                myText: String = "", optional: String? = nil) {
        self._myNum = myNum
        self._fixedText = fixedText
        self.myText = myText
        self.optional = optional
    }

    public var body: some View {
        VStack {
            if optional != nil {
                Text(optional!)
            }
            Text(myText)
            Text("Parent number: \(myNum)")
            Text("\(fixedText)")
            Button("Increment num") {
                self.myNum += 1
            }.foregroundColor(.blue)
            Button("Change Parent Text") {
                self.fixedText = "Only Changes Child"
            }.foregroundColor(.blue)
        }.background(Color.red)
            .foregroundColor(.white)
    }
}

и использование:

@State private var myNum: Int = 1
@State private var parentText = "Test"
var body: some View {
    SampleView(myNum: $myNum,
               fixedText: $parentText,
               myText: "Display Text Passed from parent")
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...