SwiftUI - ScrollViewReader#39;s scrollTo does not scroll(SwiftUI-ScrollViewReader的ScrollTo不滚动)
本文介绍了SwiftUI-ScrollViewReader的ScrollTo不滚动的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个简单的SwiftUI列表,希望在用户单击按钮时滚动到一行。我已经从hackingwithswift复制了此代码。它应该可以工作,但它没有工作。
struct ContentView: View {
var body: some View {
ScrollViewReader { proxy in
VStack {
Button("Jump to #50") {
proxy.scrollTo(5, anchor: .top)
}
List(0..<100) { i in
Text("Example (i)")
.id(i)
}
}
}
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
}
}
我在iOS 14.2上分别在模拟器和物理设备上进行了测试。
我读了它的documentation,但信息不多。那么如何滚动到一行,例如第50行呢?
推荐答案
ScrollViewReader
仅适用于:
- 显式使用
ScrollView
- 可识别集合列表
它不能与Range<Int>
的List
一起使用,除非您显式设置其id
。
显式设置ID。
// List(0..<100, id: .self)
struct ContentView: View {
var body: some View {
ScrollViewReader { proxy in
VStack {
Button("Jump to #50") {
proxy.scrollTo(5, anchor: .top)
}
List(0..<100, id: .self) { i in
Text("Example (i)")
.id(i)
}
}
}
}
}
// ForEach(0..<50000, id: .self)
struct ContentView: View {
var body: some View {
ScrollView {
ScrollViewReader { proxy in
LazyVStack {
ForEach(0..<50000, id: .self) { i in
Button("Jump to (i+500)") {
proxy.scrollTo(i+500, anchor: .top)
}
Text("Example (i)")
.id(i)
}
}
}
}
}
}
这篇关于SwiftUI-ScrollViewReader的ScrollTo不滚动的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:SwiftUI-ScrollViewReader的ScrollTo不滚动
基础教程推荐
猜你喜欢
- 如何在没有IB的情况下将2个按钮添加到右侧的UINavigationbar? 2022-01-01
- Kivy Buildozer 无法构建 apk,命令失败:./distribute.sh -m “kivy"d 2022-01-01
- android 应用程序已发布,但在 google play 中找不到 2022-01-01
- 如何让对象对 Cocos2D 中的触摸做出反应? 2022-01-01
- Android:对话框关闭而不调用关闭 2022-01-01
- UIWebView 委托方法 shouldStartLoadWithRequest:在 WKWebView 中等效? 2022-01-01
- 在 gmail 中为 ios 应用程序检索朋友的朋友 2022-01-01
- 如何在 UIImageView 中异步加载图像? 2022-01-01
- 如何在 iPhone 上显示来自 API 的 HTML 文本? 2022-01-01
- 当从同一个组件调用时,两个 IBAction 触发的顺序是什么? 2022-01-01