iOS开发 SwiftUI 14:ScrollView 滚动视图

很多时候内容确实比屏幕大,也不是什么都能用缩放来解决,此时能滚动查看就是非常理想的。

目录

ScrollView

滚动条


ScrollView

我们先写一个超出屏幕宽度的文本:

Swift 复制代码
Text("Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA")

效果是屏幕上下居中并自动换行:

放入ScrollView里面:

Swift 复制代码
            ScrollView(.horizontal){
                Text("Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA")
            }

效果:

仍然上下居中但是没有自动换行。此时可以滚动屏幕来看到超出屏幕宽度的部分:

注意文本最后一个字符是"A",说明确实看到全部了。

再加点超大图片,套个竖向ScrollView,实现上下左右都能滑动:

Swift 复制代码
        ScrollView(.vertical){
            ScrollView(.horizontal){
                Text("Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA")
                Image("pic1")
                Image("pic2")
            }
        }

因为图片非常大,会把文字顶到找不到:

上下左右滑动找找:

滚动条

仔细观察会发现上下滚动会出滚动条,左右滚动却不会出滚动条。关闭滚动条:

Swift 复制代码
ScrollView(.vertical,showsIndicators: false){
......
}

将上面的ScrollView套在Form里并给上下增加一个Text:

Swift 复制代码
    var body: some View {
        Form{
            Text("a")
            ScrollView(.vertical,showsIndicators: false){
                ScrollView(.horizontal){
                    Text("Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA")
                    Image("pic1")
                    Image("pic2")
                }
            }
            Text("b")
        }
    }

效果并不如我们预期,虽然确实显示了Form的框架,但仍然是整个屏幕滚动,而不是在Form里面滚动,而且,滚动时横竖滚动条都出现了(但是横向滚动条确实是显示在ScrollView里面的)。效果:

后一张横向滚动时并没有观察到横向滚动条。考虑到套了Form,我们去掉Form看看效果,下面的代码没有套Form并增加了一个独立的横向ScrollView:

Swift 复制代码
    var body: some View {
        Text("a")

        ScrollView(.horizontal) {
            Text("Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA")
        }

        ScrollView(.vertical, showsIndicators: false) {
            ScrollView(.horizontal) {
                Text(
                    "Hello, World!aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaA"
                )
                Image("pic1")
                Image("pic2")
            }
        }
        Text("b")
    }

效果:

这下效果符合预期,两个ScrollView独立滚动,仔细观察滚动条发现,横向滚动条显示在ScrollView的底部,如果进行了纵向滚动,滚动条就被滚到下面看不见了,这应该是个BUG。至于前面套了Form的问题,大概是Form的处理造成的(局部小面积滚动也不合理,ScrollView之内放Form才合适)。

相关推荐
初级代码游戏4 小时前
iOS开发 SwitftUI 13:提示、弹窗、上下文菜单
ios·swiftui·swift·弹窗·消息框
zhyongrui7 小时前
托盘删除手势与引导体验修复:滚动冲突、画布消失动画、气泡边框
ios·性能优化·swiftui·swift
zhangfeng113310 小时前
CSDN星图 支持大模型微调 trl axolotl Unsloth 趋动云 LLaMA-Factory Unsloth ms-swift 模型训练
服务器·人工智能·swift
Boxsc_midnight10 小时前
【openclaw+imessage】【免费无限流量】集成方案,支持iphone手机+macos
ios·智能手机·iphone
感谢地心引力20 小时前
安卓、苹果手机无线投屏到Windows
android·windows·ios·智能手机·安卓·苹果·投屏
2501_915918411 天前
HTTPS 代理失效,启用双向认证(mTLS)的 iOS 应用网络怎么抓包调试
android·网络·ios·小程序·https·uni-app·iphone
Swift社区1 天前
Flutter 路由系统,对比 RN / Web / iOS 有什么本质不同?
前端·flutter·ios
zhyongrui1 天前
SnipTrip 发热优化实战:从 60Hz 到 30Hz 的性能之旅
ios·swiftui·swift
Andy Dennis1 天前
ios开发 xcode配置
ios·cocoa·xcode