[SwiftUI]List内のButtonやLinkのデザインをNavigationLinkっぽくする方法
data:image/s3,"s3://crabby-images/7f298/7f298321cec52ca81a7af22055d45e14eccaaa52" alt=""
SwiftUIのリストにNavigationLink
を入れるとAccessoryTypeがdisclosureIndicator
なTableViewCellになってくれますが、URLを開くLink
やButton
だとこのデザインにすることができません。
NavigationLink
みたいなデザインにするButtonStyle
はないので、そういう時はLink
やButton
のlabel
を以下のようにして、右側にchevron.right
を並べてやるとそれっぽくなります。
HStack {
Text("テキスト")
.foregroundColor(.primary)
Spacer()
Image(systemName: "chevron.right")
.font(Font.system(size: 14, weight: .semibold))
.foregroundColor(.secondary)
.opacity(0.5)
}
ちなみに、なぜ新しいButtonStyleを作らないのかというと、新しくButtonStyleを追加したらタップ時に背景が変わらなくなるからです。頻繁に使いたいのであればタップ時の色変更も考慮してButtonStyleを作るのが楽だと思います。
まあ、とりあえずiOS 14ではこれでいけそうなので、困っていたらぜひ。
コメント