如何解决ScrollView + LazyStacks 卡顿
在使用 ScrollView
和 LazyVStack
/ LazyHStack
时,我遇到了许多与 this 类似的问题,其中惰性堆栈的内容在跳到ScrollView
。
首先我认为这可能是由于在延迟堆栈上使用复杂的视图会导致 SwiftUI 中的布局问题,但我设法想出了一个使用非常简单的视图层次结构的 MWE,问题仍然存在。
当快速向左滚动并在 ScrollView
的前缘弹跳时,这会导致卡顿:
ScrollView(.horizontal) {
LazyHStack {
Color.red.frame(width: 450)
Color.green.frame(width: 250)
Color.blue.frame(width: 250)
}
}
.frame(width: 350)
减小第一个视图的宽度使口吃消失
ScrollView(.horizontal) {
LazyHStack {
Color.red.frame(width: 400) //<- No stutter
Color.green.frame(width: 250)
Color.blue.frame(width: 250)
}
}
.frame(width: 350)
对于这个 MWE,口吃似乎只发生在设备上(可能是因为我在模拟器中滚动速度不够快)。但是,我在具有更复杂视图的模拟器中遇到了同样的问题。
知道这是 SwiftUI 中的错误吗?
在装有 Xcode 13 beta 1 和 iOS 15 的 iPhone Xs Max 上进行测试。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。