Как использовать список в SwiftUI - PullRequest
0 голосов
/ 27 октября 2019

У меня есть WorkoutView, и ошибка возникает в «List (workouts, id: .id)». Ошибка «Type '_» не имеет члена «id». Вот представление:

struct WorkoutsView: View {
@State var presentBuilder = false
var workouts = WorkoutData.data()

var body: some View {
    NavigationView {
        List(workouts, id: \.id) { workout in
            NavigationLink(destination: WorkoutDetailView()) {
                WorkoutBlockView(name: workout.name, workoutLength: workout.length, amountCompleted: workout.completed())
            }
        }
        .navigationBarItems(leading:
            Button(action: {
                self.presentBuilder.toggle()
            }, label: {
                ZStack {
                    Circle()
                        .foregroundColor(.blue)
                        .frame(width: 30, height: 30)
                        .shadow(radius: 7.0)
                    Image("add")
                        .foregroundColor(.black)
                }
            })
        )
    }.sheet(isPresented: $presentBuilder) {WorkoutBuilderView()}

}

}

А вот WorkoutData / Workout:

struct WorkoutData {
static func data() -> [Workout] {
    return [Workout(length: 17, name: "Example Workout", description: "workout description"), Workout(length: 17, name: "Example Workout", description: "workout description")]
}
}

struct Workout {
let id = UUID()
var progress = 1
var length: Int
var name: String
var description: String

func completed() -> Int {
    return progress - 1
}

Если я правильно понимаю, список не может определить тип тренировок и, следовательно, не может найти идентификатор. Может быть, мне нужно, чтобы Workout соответствовал опознаваемому (пробовал это)? Спасибо!

Ответы [ 2 ]

0 голосов
/ 27 октября 2019

Это не имеет ничего общего с вашим (".id"). такая ошибка List вызвана тем, что некоторые View внутри ViewBuilder не верны.

Если я заменим

 1. WorkoutDetailView()) 
 2. WorkoutBlockView(name: workout.name, workoutLength: workout.length, amountCompleted: workout.completed())
 3. WorkoutBuilderView() 

на Text, левый макет WorkoutsView будет работать. Поэтому вы должны выяснить, почему у этих представлений есть некоторые проблемы.

    struct WorkoutsView: View {
   @State var presentBuilder = false
    var workouts = WorkoutData.data()

 var body: some View {
   NavigationView {
    List(workouts, id: \.id) { workout in
        NavigationLink(destination: Text("placeHolder")) {
            Text("placeHolder")
        }
    }
    .navigationBarItems(leading:
        Button(action: {
            self.presentBuilder.toggle()
        }, label: {
            ZStack {
                Circle()
                    .foregroundColor(.blue)
                    .frame(width: 30, height: 30)
                    .shadow(radius: 7.0)
                Image("add")
                    .foregroundColor(.black)
            }
        })
    )
   }.sheet(isPresented: $presentBuilder) {Text("placeHolder")}

 }

 }

Надеюсь, что это может помочь вам.

0 голосов
/ 27 октября 2019

Я работаю над чем-то похожим на прототип SwiftUI. Я использовал HStack, но я думаю, что вы сможете сделать это, сделав перечислимый класс Hashable.

struct Statistic: Hashable {
    let title, stat: String
}
// ... 
let boxes: [Statistic]
// ... 
ScrollView(.horizontal, showsIndicators: false) {
    HStack {
        ForEach(boxes, id: \.self) { box in
            BoxView(box: box)

        }
    }
}

В вашем случае, я думаю, вы создадите Workout hashable

struct Workout: Hashable {
    let id = UUID()
    var progress = 1
    var length: Int
    var name: String
    var description: String

    func completed() -> Int {
        return progress - 1
    }
}

и будете использовать self вместо id

List(workouts, id: \.self) { workout in
...