SwiftUI - 列表:在 iOS 13+ 中隐藏分隔符
SwiftUI - List: Hide divider in iOS 13+
我使用 SwiftUI 开发了一个聊天屏幕。当前的最低 iOS 版本是 13.0。
为了进行聊天,我将元素列表与 ForEach 结合使用。
问题是列表显示了分隔符,我需要隐藏它们:
我试图隐藏 TableView 的样式,但没有任何效果。
这是代码:
struct MessagesView: View {
var messages: [MessageModel] = []
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 {
ForEach(messages, id: \.messageId) { message in
Group {
if(messPack.user != nil) {
ReceivedMessageView(
message: message.message,
name: message.user?.name,
color: message.user?.color)
} else {
SentMessageView(message: messPack.message)
}
}.listRowInsets(EdgeInsets())
}
}
}
}
如有任何帮助,我将不胜感激:)
您可以试用一些 ListView 样式。我认为 SidebarListStyle 没有任何线条。否则,您可能必须使用 ScrollView and/or VStack 而不是 List。
List {
Text("ONE")
Text("TWO")
Text("THREE")
}
.listStyle(SidebarListStyle())
将最低 iOS 版本设置为 iOS 13 并不意味着您的代码不能 运行 iOS 14(和 iOS 13 解决方案删除列表分隔符不适用于 iOS 14).
您需要使用 if #available(iOS 14, *)
指定哪个代码用于哪个 iOS 版本:
struct MessagesView: View {
var messages: [MessageModel] = []
init() {
UITableView.appearance().tableFooterView = UIView()
UITableView.appearance().separatorStyle = .none
}
var body: some View {
List {
ForEach(messages, id: \.messageId) { message in
Group {
if #available(iOS 14, *) {
messageView(for: message)
.frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .leading)
.listRowInsets(EdgeInsets())
.background(Color.white)
} else {
messageView(for: message)
}
}
}
}
}
@ViewBuilder
func messageView(for message: MessageModel) -> some View {
if messPack.user != nil {
ReceivedMessageView(
message: message.message,
name: message.user?.name,
color: message.user?.color
)
} else {
SentMessageView(message: messPack.message)
}
}
}
删除 List
分隔符:
- iOS 13 -
- iOS 14 -
我使用 SwiftUI 开发了一个聊天屏幕。当前的最低 iOS 版本是 13.0。
为了进行聊天,我将元素列表与 ForEach 结合使用。 问题是列表显示了分隔符,我需要隐藏它们:
我试图隐藏 TableView 的样式,但没有任何效果。 这是代码:
struct MessagesView: View {
var messages: [MessageModel] = []
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 {
ForEach(messages, id: \.messageId) { message in
Group {
if(messPack.user != nil) {
ReceivedMessageView(
message: message.message,
name: message.user?.name,
color: message.user?.color)
} else {
SentMessageView(message: messPack.message)
}
}.listRowInsets(EdgeInsets())
}
}
}
}
如有任何帮助,我将不胜感激:)
您可以试用一些 ListView 样式。我认为 SidebarListStyle 没有任何线条。否则,您可能必须使用 ScrollView and/or VStack 而不是 List。
List {
Text("ONE")
Text("TWO")
Text("THREE")
}
.listStyle(SidebarListStyle())
将最低 iOS 版本设置为 iOS 13 并不意味着您的代码不能 运行 iOS 14(和 iOS 13 解决方案删除列表分隔符不适用于 iOS 14).
您需要使用 if #available(iOS 14, *)
指定哪个代码用于哪个 iOS 版本:
struct MessagesView: View {
var messages: [MessageModel] = []
init() {
UITableView.appearance().tableFooterView = UIView()
UITableView.appearance().separatorStyle = .none
}
var body: some View {
List {
ForEach(messages, id: \.messageId) { message in
Group {
if #available(iOS 14, *) {
messageView(for: message)
.frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .leading)
.listRowInsets(EdgeInsets())
.background(Color.white)
} else {
messageView(for: message)
}
}
}
}
}
@ViewBuilder
func messageView(for message: MessageModel) -> some View {
if messPack.user != nil {
ReceivedMessageView(
message: message.message,
name: message.user?.name,
color: message.user?.color
)
} else {
SentMessageView(message: messPack.message)
}
}
}
删除 List
分隔符:
- iOS 13 -
- iOS 14 -