SwiftUI - 视图布局和演示
2023-06-14 本文已影响0人
yytmzys
1 HStack, 将子视图横向 水平 排列。
创建文本 横向 展示
HStack (alignment: .center, spacing: 20){
Text("Hello")
Divider()
Text("World")
}
data:image/s3,"s3://crabby-images/5cb72/5cb72a3aa10f42e094b0a8f67d868466c9143b1a" alt=""
1.1 LazyHStack, 创建滑动列表, 横向 水平 展示, 排列成一条水平增长的线的视图。
ScrollView(.horizontal) {
LazyHStack(alignment: .center, spacing: 20) {
ForEach(1...100, id: \.self) {
Text("Column \($0)")
}
}
}
data:image/s3,"s3://crabby-images/94be3/94be3317c46bc74e5a78595306a5756f57e601d1" alt=""
2 VStack, 将其子级排列成一条垂直线的视图。
创建 纵向 竖直 可滚动列表
VStack (alignment: .center, spacing: 20){
Text("Hello")
Divider()
Text("World")
}
data:image/s3,"s3://crabby-images/a4b9b/a4b9b7f4e0cd08b8db2c054f4862cbc4c39ee7e5" alt=""
2.1 LazyVStack, 将其子项排列成一条垂直排列的视图,创建项目仅在需要时。
ScrollView(.vertical) {
LazyVStack(alignment: .center, spacing: 20) {
ForEach(1...100, id: \.self) {
Text("Column \($0)")
}
}
}
data:image/s3,"s3://crabby-images/f6e7a/f6e7a3e71e2e5d8744e71b84ae108c035aa87263" alt=""
3 ZStack, 重叠 覆盖 其子级的视图,使它们在两个轴上对齐。
ZStack {
Text("Hello")
.padding(10)
.background(Color.red)
.opacity(0.8)
Text("World")
.padding(20)
.background(Color.red)
.offset(x: 0, y: 40)
}
data:image/s3,"s3://crabby-images/f9b1f/f9b1fd74d0c799e18990ccd82d107c2c3bd8a4fe" alt=""
4 混合排版
Text("Hello world")
Image(systemName: "clock")
data:image/s3,"s3://crabby-images/f49aa/f49aa586bfe04319c7ef807aa3c993a8ab0a0dcf" alt=""