macos - 使用 SwiftUI 在 macOS 中设置 SidebarView 的宽度
问题描述
我正在使用 NavigationView 在 Mac 应用程序的窗口中显示 SidebarView 和 DetailView:
import SwiftUI
private let fruits = [" Apple", " Coconut", " Mango", " Kiwi"]
struct SidebarView: View {
@Binding var selectedFruit: String?
var body: some View {
List(fruits, id: \.self, selection: $selectedFruit) { fruit in
Text("\(fruit)")
}
.listStyle(SidebarListStyle())
.frame(minWidth: 180, idealWidth: 200, maxWidth: 300)
}
}
struct DetailView: View {
@Binding var fruit: String?
var body: some View {
Text("\(fruit ?? "Default Fruit")")
.font(.headline)
.frame(maxWidth: .infinity, maxHeight: .infinity)
}
}
struct ContentView: View {
@State private var selectedFruit: String?
var body: some View {
NavigationView {
SidebarView(selectedFruit: $selectedFruit)
DetailView(fruit: $selectedFruit)
}
.frame(width: 500, height: 400)
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
}
}
SidebarView 的宽度可以通过在窗口中向左或向右拖动中心分隔线来调整。我想为侧边栏定义200的初始宽度以及180的最小宽度和300的最大宽度。我通过设置确实设置最大宽度但侧边栏仍然可以彻底崩溃。此外,侧边栏的初始宽度似乎由minWidth
not定义idealWidth
。
解决方案
对于发现这个并想知道如何在 macOS 中设置侧边栏的 maxWidth 的任何人,你真的不知道。如果这样做,视图将停止增长,然后被夹在边栏的中间,边栏将继续扩大。
我花了一分钟才弄清楚这一点,但你要做的是设置另一个视图的 minWidth,即详细视图。并且侧边栏会增长直到它不能增长。您会注意到,即使是 Finder 的侧边栏也会不断增长,直到达到细节的 minWidth,可以这么说。
推荐阅读
- json - 链接 JQ if: if A then BC else D end
- python - 如何在 Django Rest 中向 APIView 添加过滤?
- react-native - 无法为 FlatList 项目分配宽度
- java - 如何在调用 JVM 的关闭挂钩之前关闭 @SpringBootTest 上下文(一次,在所有 JUnit 测试之后)
- gcc - _mm256_fmadd_ps 比 _mm256_mul_ps + _mm256_add_ps 慢?
- javascript - 组合 2 个不同长度的数组,重复较短的数组以匹配较长数组的长度
- kubernetes - 当我放置 2 条路径时,使用 nginx 入口控制器的入口不起作用
- kubernetes - Spring Cloud 数据流日志级别
- python - Pandas - 合并较小的类别
- visual-studio-code - 如何在 VSC 中获取 html 建议格式?