In SwiftUI List, you can use the listSectionSpacing
view modifier for List
view to control how much space is in between different sections.
Base code
We will use this code as a starting point:
//
// ListSpacingControl.swift
// WhatsNewIniOS18
//
// Created by Msz on 8/10/24.
//
import SwiftUI
struct ListSpacingControl: View {
let planets: [String] = ["Earth", "Mars", "Jupiter", "Saturn", "Uranus", "Neptune"]
let closeGalaxies = [
"Milky Way",
"Andromeda Galaxy",
"Large Magellanic Cloud",
"Small Magellanic Cloud",
"Triangulum Galaxy"
]
var body: some View {
List {
Section("Planets") {
ForEach(planets, id: \.self) { planet in
Text(planet)
}
}
Section("Galaxies") {
ForEach(closeGalaxies, id: \.self) { planet in
Text(planet)
}
}
}
.listSectionSpacing(.default)
}
}
#Preview {
ListSpacingControl()
}
Default spacing
Here, you can set the default spacing using the .default
as the input to the view modifier.
data:image/s3,"s3://crabby-images/ee9e7/ee9e76ccda92a08323e64b1e5323905bee59c93e" alt=""
Compact spacing
You can set it to compact
for relatively small spacing between different sections.
data:image/s3,"s3://crabby-images/de724/de72486b284fa3f10e645e399f2e3c0c446f25b9" alt=""
Custom spacing
You can set a custom spacing by providing a number.
data:image/s3,"s3://crabby-images/bf21d/bf21dd6a2b9bf3a8f26f85ef3dea821faf972fc9" alt=""