我尝试学习SwiftUI,但我不明白为什么这在Apple教程中有效,但在我自己的项目中无效。我想使用自己的设计,这意味着NavigationLink
看起来像一个普通的Button。问题在于,它只能使用一次,而当我使用<返回按钮时,我将无法再次使用“编辑”按钮。
import SwiftUI
import Foundation
struct TimeTrackerView: View {
@ObservedObject var timeTracker = TimeTracker()
@State private var isStart = false
var body: some View {
NavigationView {
ZStack {
Color.black
.edgesIgnoringSafeArea(.all)
VStack {
Spacer()
Text( timeString(time: self.timeTracker.time) )
.font(.largeTitle)
.foregroundColor(.white)
.padding(50)
Spacer()
HStack {
Group {
Button(action: {
self.isStart.toggle()
if self.isStart {
self.timeTracker.startTimer()
} else {
self.timeTracker.stopTimer()
}
}) {
if isStart {
Text("Stop")
.foregroundColor(.red)
} else {
Text("Start")
.foregroundColor(.white)
}
}
Spacer()
// BUG: Button works only once
NavigationLink(destination: TimeDetail()) {
Text("Edit")
.foregroundColor(.white)
}
}
}
.font(.title).padding(50)
}
}
.navigationBarTitle("Navigation")
}
}
}
func timeString(time: Int) -> String {
let hours = time / 3600
let minutes = time / 60 % 60
let seconds = time % 60
return String(format:"%1ih %1im %1is", hours, minutes, seconds)
}
struct TimeTrackerView_Previews: PreviewProvider {
static var previews: some View {
TimeTrackerView()
}
}
这是TimeDetail视图。
import SwiftUI
struct TimeDetail: View {
var body: some View {
Group {
Text("HI, i'm View")
}.navigationBarTitle("Navi", displayMode: .inline)
}
}
struct TimeDetail_Previews: PreviewProvider {
static var previews: some View {
TimeDetail()
}
}
我发现当我将List
与NavigationLink
一起使用时,它可以工作。但是没有一个按钮。