What is the difference between List and ForEach in SwiftUI
Table of Contents
What is the difference between List and ForEach in SwiftUI
Even though ForEach
and List
have similar syntax, they serve different purposes.
ForEach(contacts, id: \.self) { contact in
Text(contact)
}
List(contacts, id: \.self) { contact in
Text(contact)
}
ForEach
ForEach
is a view that creates an array of views from an underlying collection of data.
You can think of it as a map function that turns an array of data into multiple views.
struct ContentView: View {
let contacts = [
"John",
"Alice",
"Bob",
"Foo",
"Bar"
]
var body: some View {
ForEach(contacts, id: \.self) { contact in
Text(contact)
}
}
}
The above code is equivalent to
struct ContentView: View {
var body: some View {
Text("John")
Text("Alice")
Text("Bob")
Text("Foo")
Text("Bar")
}
}
ForEach
doesn't contain any style. The result is an array of views.
By default, views without any container view will lay out vertically.
List
List
or UITableView
in UIKit is a complex view structure that compose many features and styles.
Here are some of the List characteristics.
- Display a collection of views as rows in a column.
- Automatically provides scrolling when the content is too large for the current display.
- Many built-in appearance features that you can configure using view modifiers, e.g., list styles, headers, footers, sections, and separators.
- Many built-in user interactions, e.g., selecting, adding, deleting, and reordering.
In brief, List
is a container view that turns a collection of views into a list structure.
struct ContentView: View {
var body: some View {
List {
Text("John")
Text("Alice")
Text("Bob")
Text("Foo")
Text("Bar")
}
}
}
List
turn a collection of text views into a list structure. Each text view becomes a row's content.
As you can see, each row has a line separator and groups into the same section with round corners around them. These are all styles by a List
view.
Using ForEach in List
Since ForEach
can turn an array of data into a collection of views and List
can turn those views into a list structure.
We can use ForEach
inside a List
view.
struct ListForEachExample: View {
let contacts = [
"John",
"Alice",
"Bob",
"Foo",
"Bar"
]
var body: some View {
List {
ForEach(contacts, id: \.self) { contact in
Text(contact)
}
}
}
}
The result will be the same as our previous example.
List {
Text("John")
Text("Alice")
Text("Bob")
Text("Foo")
Text("Bar")
}
Creating a list from a collection of data is a very common pattern. Having to use ForEach
inside List
every time might be cumbersome.
Luckily, List
has an initializer with the same syntax as ForEach
. So, we can achieve the same result using this initializer.
List(contacts, id: \.self) { contact in
Text(contact)
}
You can easily support sarunw.com by checking out this sponsor.
Screenshot Studio: Create App Store screenshots in seconds not minutes.
Conclusion
ForEach
is a view that creates an array of views from an underlying collection of data. The resulting views can be used within other container views, e.g., VStack
, HStack
, and List
.
List
is a container view that turns a collection of views into a list structure.
Read more article about SwiftUI, List, ForEach, or see all available topic
Enjoy the read?
If you enjoy this article, you can subscribe to the weekly newsletter.
Every Friday, you'll get a quick recap of all articles and tips posted on this site. No strings attached. Unsubscribe anytime.
Feel free to follow me on Twitter and ask your questions related to this post. Thanks for reading and see you next time.
If you enjoy my writing, please check out my Patreon https://www.patreon.com/sarunw and become my supporter. Sharing the article is also greatly appreciated.
Become a patron Buy me a coffee Tweet ShareShould we manually call @StateObject initializer
Is it OK to manually initialize @StateObject? Let's find out.