Posted on 7 Dec 2023 . 3 min read
In SwiftUI, the ForEach is used to iterate over a collection of data and create views dynamically based on that data. If you need the index of the current element while using ForEach, you can achieve this by using the following ways along with ForEach:
If you want to use a range of indices with a count in SwiftUI’s ForEach loop, you can create a Range and iterate through it. Here's an example:
import SwiftUI
struct ContentView: View {
let items = ["Milk", "Bread", "Cookies", "Tea"]
var body: some View {
VStack {
ForEach(0..<items.count, id: \.self) { index in
Text("\(index): \(items[index])")
}
}
}
}
In this example:
This method allows you to iterate through a range of indices based on the count of your collection and access the elements within the ForEach loop in SwiftUI.
In SwiftUI, you can use the indices property of a collection to access the indices while iterating through the elements using ForEach. Here's an example of how you can use indices to get the index within a ForEach loop. Here’s an example:
import SwiftUI
struct ContentView: View {
let items = ["Milk", "Bread", "Cookies", "Tea"]
var body: some View {
VStack {
ForEach(items.indices, id: \.self) { index in
Text("\(index): \(items[index])")
}
}
}
}
In this example:
This approach allows you to iterate through the indices of the collection and use those indices to access the elements within the ForEach loop in SwiftUI.
If you need the index of the current element while using ForEach, you can achieve this by using the enumerated() method along with ForEach. Here’s an example:
import SwiftUI
struct ContentView: View {
let items = ["Milk", "Bread", "Cookies", "Tea"]
var body: some View {
VStack {
ForEach(Array(items.enumerated()), id: \.1) { index, item in
Text("\(index): \(item)")
}
}
}
}
In this example:
This way, you can access the index and item simultaneously within the ForEach loop in SwiftUI.
Don’t hesitate to contact me if you have any questions or queries. Follow me on twitter @gurjitpt for any updates.
Thanks!
Written By
Gurjit Singh
I’m Computer Science graduate and an iOS Engineer who writes about Swift and iOS development. Follow me for more updates:
Discover articles by topics
SwiftUI Class Struct Networking XCode NSCache Enum Optionals Property Observers Closures Guard Reviews StoreKit App Store Algorithms Testing Operators Protocol Extensions Weak Unowned SwiftData WWDC23 GCD API Admob SwiftLint Lottie Foreach Objective-C UIKit NavigationSplitView