SwiftUI 中列表的推荐方式是使用 List 作为控件(类似 UITableView)。通常我们使用列表的时候都有修改背景色或者自定义背景的需求。
起初,你以为像其他控件一样使用 background 就可以了,比如这样:
swift
List {
Section {
Text("Item 1")
}
Section {
Text("Item 2")
Text("Item 3")
Text("Item 4")
}
Section {
Text("Item 5")
Text("Item 6")
Text("Item 7")
}
}
.background(.pink)
然而你跑起来以后会发现这个背景没起作用。
经过视图调试你会发现,是因为 tableView 控件自带了一个背景,我们自定义的背景在 List 的下面一层,被遮住了,所以没有效果。
data:image/s3,"s3://crabby-images/98aca/98acae10eeabe35105f2b70b7f1d416ef1e14938" alt=""
难道就没有一个隐藏 List 背景图层的接口吗?
一问一个不吱声,iOS 16之前还真没有。
data:image/s3,"s3://crabby-images/41c02/41c02d8761791ea3838ffeeb33a7d1341fffed99" alt=""
在 iOS 16 上终于良心发现增加了一个 scrollContentBackground(.hidden)
。
swift
List {
Section {
Text("Item 1")
}
Section {
Text("Item 2")
Text("Item 3")
Text("Item 4")
}
Section {
Text("Item 5")
Text("Item 6")
Text("Item 7")
}
}
.background(.pink)
.scrollContentBackground(.hidden)
隐藏了原生列表的背景图层以后自定义的背景就可以正常使用了。
data:image/s3,"s3://crabby-images/82cb0/82cb0b1266928a6d39edbb0b36955d420cf45310" alt=""
使用图片之类的是也可以的。
data:image/s3,"s3://crabby-images/1fcd5/1fcd586927124a728c20605829cb8784bd8096e3" alt=""