Sha*_*man 3 swift swiftui hstack swiftui-navigationlink
我正在开发我的第一个 SwiftUI 应用程序,并希望在其中显示一个List类别,并用一个徽章指示该类别中的项目数量。类别的标题将位于左侧,徽章将在行中右对齐。该列表将由NavigationLinks 组成,因此点击其中一个将进一步深入到视图层次结构。我编写的用于渲染 s 的代码NavigationLink如下所示:
List {
ForEach(myItems.indices) { categoryIndex in
let category = categories[categoryIndex]
let title = category.title
let fetchReq = FetchRequest<MyEntity>(entity: MyEntity(),
animation: .default)
NavigationLink(destination: MyItemView()) {
HStack(alignment: .center) {
Text(title)
Spacer()
ZStack {
Circle()
.foregroundColor(.gray)
Text("\(myItemsDict[category]?.count ?? 0)")
.foregroundColor(.white)
.font(Font.system(size: 12))
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
虽然它确实呈现了一个功能性的NavigationLink,但徽章并没有像我所希望的那样右对齐显示。相反,它看起来像这样:
我知道我被某些事情所困扰HStack,但不确定是什么。如何才能使类别标题文本占据行的大部分,并且徽章在行中右对齐?
SwiftUI 不知道你的Circle应该有多大,所以Spacer不会做任何事情。你应该给它设置一个固定的框架。
struct ContentView: View {
var body: some View {
List {
ForEach(0..<2) { categoryIndex in
let title = "Logins"
NavigationLink(destination: Text("Hi")) {
HStack(alignment: .center) {
Text(title)
Spacer()
ZStack {
Circle()
.foregroundColor(.gray)
.frame(width: 25, height: 25) // here!
Text("5")
.foregroundColor(.white)
.font(Font.system(size: 12))
}
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
结果:
| 归档时间: |
|
| 查看次数: |
594 次 |
| 最近记录: |