这个问题在这里已经有了答案:
How to remove "row" separators/dividers from a List in SwiftUI?
(8 个回答)
12 个月前关闭。
我试图隐藏列表中单元格之间的分隔线,但根据 Apple 的文档,似乎没有办法做到这一点。
知道怎么做吗?
最佳答案
iOS 15:
今年苹果推出了新的修改器.listRowSeparator
可用于设置分隔符的样式。您可以通过.hidden
隐藏它:
List {
ForEach(items, id:\.self) {
Text("Row \($0)")
.listRowSeparator(.hidden)
}
}
iOS 14
在 iOS 14 中,您可以考虑使用
LazyVStack
而不是为此列出:ScrollView {
LazyVStack {
ForEach((1...100), id: \.self) {
Text("Placeholder \($0)")
}
}
}
请记住,LazyVStack
很懒惰,不会一直渲染所有行。因此它们的性能非常好,并且是 Apple 自己在 WWDC 2020 中推荐的。iOS 13
有一个
UITableView
SwiftUI 的背后 List
对于 iOS。所以要删除额外的分隔符(在列表下方):
您需要一个
tableFooterView
并删除所有分隔符(包括实际分隔符):
您需要
separatorStyle
成为 .none
init() {
// To remove only extra separators below the list:
UITableView.appearance().tableFooterView = UIView()
// To remove all separators including the actual ones:
UITableView.appearance().separatorStyle = .none
}
var body: some View {
List {
Text("Item 1")
Text("Item 2")
Text("Item 3")
}
}
关于swiftui - 如何隐藏 SwiftUI 列表分隔符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56529765/