我有一个大约 100 行的视图:
ForEach(moodEntries.reversed(), id: \.self) { entry in
Button(action: {
self.activeMoodForModal = moodEntries.lastIndex(of: entry) ?? 0
self.showMoodModal.toggle()
}) {
MoodTableViewCard(entry: entry)
}
}.sheet(item: $activeMoodForModal) { item in
MoodEntryModalView(entry: moodEntries[item], saveNote: {
do {
try context.save()
} catch {
print(error)
}
})
}
性能真的很糟糕:当我打开这个视图时,整个应用程序在模拟器上冻结了 3 秒。如果我改变ForEach
to List
一切正常,所以我想延迟加载会解决我的问题。但我不想弄乱 List 所以我尝试将上面提到的所有代码放在LazyVStack { }
但这并没有帮助:代码的性能和以前一样糟糕。是LazyVStack
真的比List
或者也许我做错了什么?
LazyVStack
does not完全重用单元格,所以无论你做什么 - 它仍然会滞后于滚动。如果您的元素数量超出了屏幕的容纳范围并且布局比Text("Hello")
- use List
.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)