よくある入力欄を iOS で作ります。
// iOS
Form {
Section(header: Text("Name of Living Accommodation")) {
Group {
TextField("Enter place name here…", text: $placeName)
}
}
Section(header: Text("Address of Living Accommodation")) {
Group {
TextField("Enter address here…", text: $address)
}
}
}
data:image/s3,"s3://crabby-images/7a302/7a302d6b732a1c6863e7855316c5e2d08d833dd8" alt=""
いい感じです。
👉 Form | Apple Developer Documentation data:image/s3,"s3://crabby-images/dd9c7/dd9c757a81ba29191be4a98dcf4141fac5de9b09" alt="hatena-bookmark"
👉 Group | Apple Developer Documentation data:image/s3,"s3://crabby-images/4860b/4860bc1272320d2fdd55d15e32281020a841f8fe" alt="hatena-bookmark"
macOS に切り替えてみます。
data:image/s3,"s3://crabby-images/5b022/5b022d12236433bd3daab719b3fcf130bd273132" alt=""
なんか気持ちが悪いです。
以下のようにレイアウト記述を書き換えます。
iOS | macOS
-------+----------
Form → List
Group → GroupBox
// macOS
List { // *
Section(header: Text("Name of Living Accommodation")) {
GroupBox { // *
TextField("Enter place name here…", text: $placeName)
}
}
Section(header: Text("Address of Living Accommodation")) {
GroupBox { // *
TextField("Enter address here…", text: $address)
}
}
}
いい感じになりました。
data:image/s3,"s3://crabby-images/03521/03521b61635a53f9de5b7ade804d2ffc72e2c4bf" alt=""
👉 List | Apple Developer Documentation data:image/s3,"s3://crabby-images/716d8/716d8c72240644af519e6d8e2a99d0c4ab91e1f9" alt="hatena-bookmark"
👉 GroupBox | Apple Developer Documentation data:image/s3,"s3://crabby-images/9eaad/9eaad68e75277fc0fd8994864a8ccc185ee91146" alt="hatena-bookmark"
自動で切り替えるようにしておきます。
// iOS and macOS
#if os(iOS)
Form {
Section(header: Text("Name of Living Accommodation")) {
Group {
TextField("Enter place name here…", text: $placeName)
}
}
Section(header: Text("Address of Living Accommodation")) {
Group {
TextField("Enter address here…", text: $address)
}
}
}
#else
List {
Section(header: Text("Name of Living Accommodation")) {
GroupBox {
TextField("Enter place name here…", text: $placeName)
}
}
Section(header: Text("Address of Living Accommodation")) {
GroupBox {
TextField("Enter address here…", text: $address)
}
}
}
#endif
長ったらしいですね。
たった3か所の置き換えだけなのに。
■ typealias を使う
レイアウト記述の同名のエイリアスを作ってそれらを OS で切り分けます。
// iOS and macOS
#if os(iOS)
typealias TripForm = Form
typealias TripGroupBox = Group
#else
typealias TripForm = List
typealias TripGroupBox = GroupBox
#endif
typealias | iOS | macOS
--------------+-------+----------
TripForm | Form | List
TripGroupBox | Group | GroupBox
それらエイリアスを使って本体は記述する。
// iOS and macOS
TripForm { // *
Section(header: Text("Name of Living Accommodation")) {
TripGroupBox { // *
TextField("Enter place name here…", text: $placeName)
}
}
Section(header: Text("Address of Living Accommodation")) {
TripGroupBox { // *
TextField("Enter address here…", text: $address)
}
}
}
これできれいに切り替えできました !
typealias を切り替えることで、
本体コードの挙動を置き換えてます。
さすが、Apple 公式サンプルコードは勉強になります。
Trip/Trips-SwiftData/Trips/EditLivingAccommodationsView.swift
Trip/Trips-SwiftData/Trips/SwiftUIHelper.swift
以下、Apple ページ「Download」からどうぞ。
data:image/s3,"s3://crabby-images/8f37f/8f37f8e082339ced460cab6a35fd0353c73e4e14" alt=""
👉 Adopting SwiftData for a Core Data app | Apple Developer Documentation data:image/s3,"s3://crabby-images/ac842/ac8427a6388f3c40147d9a8288cd6c9b1918da92" alt="hatena-bookmark"