SwiftUIでデータを一覧表示したい場合にはListを使用します。
配列と組み合わせて使用する場合が多いのですが、データを一つずつ指定して表示することもできます。 テキストだけでなく、複数のコントロールを組み合わせて表示することができるため、データを表示するだけでなく、入力用の画面でも使用されます。
以下具体的な手順を説明します。
最もシンプルなList
最も基本的な使い方です。Listの中身が順番に表示されます。
struct ListStatic: View {
var body: some View {
List {
Text("田中")
Text("佐藤")
Text("山田")
}
}
}
実行結果です。
data:image/s3,"s3://crabby-images/58636/5863691f7514a4284e31efb4722ce56b51580806" alt=""
Listの中身はTextに限らず、Buttonなど自由に設定できます。
配列を表示するList
配列の内容をListとして表示することもできます。
struct ListArray: View {
let persons = ["田中", "佐藤", "山田"]
var body: some View {
List {
ForEach(persons, id: \.self) { person in
Text(person)
}
}
}
}
実行結果です。
data:image/s3,"s3://crabby-images/7d1c1/7d1c12f8d8d5d0d684f07d1939497edd85fff567" alt=""
実際のアプリでは配列の内容をプログラムから変更し、その内容をListとして表示する事が多いと思います。
Sectionでグループ化する
Sectionを使用してグループ化することもできます。各グループにはヘッダーを追加できます。
struct ListSection: View {
var body: some View {
List {
Section {
Text("田中")
Text("山田")
} header: {
Text("人間")
}
Section {
Text("リンゴ")
Text("バナナ")
} header: {
Text("くだもの")
}
}
}
}
実行結果です。
data:image/s3,"s3://crabby-images/cc676/cc676d27b1bc40e94758dff1f5fed641a895b898" alt=""
スタイルの指定
.listStyleモディファイアを使用して、Listのスタイルを指定することができます。
List {
(省略)
}
//デフォルトのスタイル
.listStyle(DefaultListStyle())
//プレインスタイル
.listStyle(.plain)
//グループ化されたスタイル
.listStyle(.grouped)
//マージンがあるスタイル
.listStyle(.inset)
//マージンとグループ
.listStyle(.insetGrouped)
//サイドバー
.listStyle(.sidebar)
.default
data:image/s3,"s3://crabby-images/96f92/96f92aa885c591c2799951ca49a36efccb5c92a7" alt=""
.plain
data:image/s3,"s3://crabby-images/03c6b/03c6b4609869db0ea69eb84a5c963db004dac385" alt=""
.grouped
data:image/s3,"s3://crabby-images/013bd/013bd92afc80f056013489bf1ecfe90a3b9df11c" alt=""
.inset
data:image/s3,"s3://crabby-images/d8a37/d8a37f561b60bb0feb2cf7ccbc23c4a58976ae2d" alt=""
.insetGrouped
data:image/s3,"s3://crabby-images/e364a/e364a551eea3b5018514bb67758659dc0ddaab65" alt=""
.sidebar
data:image/s3,"s3://crabby-images/64ba6/64ba6074e563a2222821433245a87a106bd7c1cd" alt=""