[英]Having trouble with crash when performing .ondelete on a list (SwiftUI).. crashing in .onReceive for a timer
[英]Timer crashing screens in SwiftUI
我有一个应用程序使用计时器以编程方式在入职屏幕上的视图之间滚动。 从入职屏幕,我可以进入登录然后注册屏幕(或个人资料然后我的帐户屏幕)。 在这两种方式中,当打开登录屏幕并单击注册时,注册屏幕会出现但随后消失并让我重新登录(当我尝试从个人资料屏幕进入我的帐户屏幕时也会发生同样的情况)。 请检查随附的 gif。
我搜索了整个网络,没有发现任何类似的问题。
注意:我正在使用 NavigationLink 在屏幕之间导航,并且我还尝试同时使用 Timer 和 Timer.TimerPublisher 导致我得到相同的结果,一旦计时器触发,屏幕就会崩溃。
注意:删除计时器(或 onReceive 中的代码)时,一切正常。 我也怀疑这个问题可能与menuIndex
有关
struct OnboardingView: View {
//MARK: - PROPERTIES
@State var menuIndex = 0
@State var openLogin = false
let timer = Timer.publish(every: 4, on: .main, in: .common).autoconnect()
//MARK: - BODY
var body: some View {
NavigationLink(destination: LoginView(), isActive: $openLogin) {}
VStack (spacing: 22) {
ProfileButton(openProfile: $openLogin)
.frame(maxWidth: .infinity, alignment: .trailing)
.padding(.horizontal, 22)
OnboardingMenuItem(text: onboardingMenu[menuIndex].title, image: onboardingMenu[menuIndex].image)
.frame(height: 80)
.animation(.easeInOut, value: menuIndex)
.onReceive(onboardingVM.timer) { input in
if menuIndex < onboardingMenu.count - 1 {
menuIndex = menuIndex + 1
} else {
menuIndex = 0
}
}
...
}
}
}
你只能有一个细节NavigationLink
,如果你想要更多,你必须设置isDetailLink(false)
,这就是你看到故障的原因。
仅供参考,您的计时器需要在@State
中,否则每次 View 初始化时它都会从零开始,例如在父View
的状态更改时。 解决这个问题的标准方法是将相关属性分组到它们自己的结构中,例如
struct OnboardingViewConfig {
var menuIndex = 0
var openLogin = false
let timer = Timer.publish(every: 4, on: .main, in: .common).autoconnect()
// mutating func exampleMethod(){}
}
struct OnboardingView: View {
@State var config = OnboardingViewConfig()
...
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.