SwiftUI 提供了许多视图组件,用于构建现代化的用户界面。这些组件功能丰富,支持响应式设计,并与 SwiftUI 的数据绑定系统无缝集成。以下是一些常用的 SwiftUI 视图组件分类及其示例:
布局组件
这些组件用于控制视图的布局和排列。
1、VStack
垂直排列子视图。
VStack {
Text("Hello")
Text("World")
}
data:image/s3,"s3://crabby-images/67dd5/67dd5770115b2d2cb662cee18c2cf5b1019f98fe" alt=""
2、HStack
水平排列子视图。
HStack {
Image(systemName: "star")
Text("Favorite")
}
data:image/s3,"s3://crabby-images/eb96f/eb96fbb3ce0b340d43ca4d4e540cd5b5b2a9b53f" alt=""
3、ZStack
将子视图叠加在一起。
ZStack {
Color.blue
Text("Hello")
.foregroundColor(.white)
}
data:image/s3,"s3://crabby-images/c876a/c876a21941a599a84e7cc562585339fec2eb1f77" alt=""
4、Grid(iOS 16+)
基于网格的布局。
Grid {
GridRow {
Text("A").background(Color.red)
Text("B").background(Color.blue)
}
GridRow {
Text("C").background(Color.green)
Text("D").background(Color.yellow)
}
}
data:image/s3,"s3://crabby-images/7fa16/7fa165fc8933b1002a86eb67b0b1b108fb637416" alt=""
5、Spacer
在布局中添加弹性间距。
HStack {
Text("Left")
Spacer()
Text("Right")
}
data:image/s3,"s3://crabby-images/c542c/c542c6df4d6adc3716c9e6a8eeddd028adfe0b44" alt=""
6、Divider
显示一条分割线。
VStack {
Text("Above Divider")
Divider()
Text("Below Divider")
}
data:image/s3,"s3://crabby-images/a96ee/a96ee44ceecba478d76a381086f572db9dc5f5cd" alt=""
文本和图像
1、Text
显示静态或动态文本。
Text("Hello, SwiftUI!")
.font(.headline)
.foregroundColor(.blue)
data:image/s3,"s3://crabby-images/5b50d/5b50dcb365e8e08e874bf2cb001f81480d276297" alt=""
2、Image
显示本地或系统图标。
Image(systemName: "star.fill")
.resizable()
.frame(width: 50, height: 50)
.foregroundColor(.yellow)
data:image/s3,"s3://crabby-images/0f9f5/0f9f53cf0e5d46219f9cb7c26768e447a58fd0ed" alt=""
输入组件
1、Button
创建可交互的按钮。
Button("Tap Me") {
print("Button tapped!")
}
data:image/s3,"s3://crabby-images/9c5b2/9c5b2d4450888a4ad84da44cf59f1d92a5f83137" alt=""
2、TextField
接受用户输入。
@State private var text = ""
TextField("Enter your name", text: $text)
.textFieldStyle(.roundedBorder)
data:image/s3,"s3://crabby-images/248a7/248a74be2bf5f6075819181345b45a1b164c695d" alt=""
3、SecureField
接受密码输入。
@State private var password = ""
SecureField("Password", text: $password)
data:image/s3,"s3://crabby-images/5aec6/5aec670665cb43cf3a559aa6b0784e91d6a8415d" alt=""
4、Toggle
开关组件。
@State private var isOn = false
Toggle("Enable Feature", isOn: $isOn)
data:image/s3,"s3://crabby-images/e5767/e5767df4c0cffac4627feabfcc8f00132c55c494" alt=""
5、Slider
滑块组件。
@State private var value: Double = 0.5
Slider(value: $value, in: 0...1)
data:image/s3,"s3://crabby-images/d94d6/d94d67cd2b9139ba80b61c2406cee65de1078823" alt=""
6、Picker
选择多个选项之一。
@State private var selectedOption = "Option 1"
let options = ["Option 1", "Option 2", "Option 3"]
Picker("Select an Option", selection: $selectedOption) {
ForEach(options, id: \.self) { option in
Text(option)
}
}
.pickerStyle(.wheel)
data:image/s3,"s3://crabby-images/a13c9/a13c905aca89d5beb61128b2f6d981434002f046" alt=""
数据显示
1、List
显示垂直列表。
let items = ["Apple", "Banana", "Cherry"]
List(items, id: \.self) { item in
Text(item)
}
data:image/s3,"s3://crabby-images/d4db9/d4db967bf31064ed0ad4fa70a8d55a778d8ece54" alt=""
2、ScrollView
可滚动视图。
ScrollView {
VStack {
ForEach(1..<50) { index in
Text("Item \(index)")
}
}
}
data:image/s3,"s3://crabby-images/18a58/18a584ba77376967b6021bef675e675a57a60a71" alt=""
3、ForEach
遍历数据以生成视图。
ForEach(1..<6) { index in
Text("Item \(index)")
}
data:image/s3,"s3://crabby-images/42726/42726773cd85f4669181a113def3f4969cad2a23" alt=""
容器和导航
1、NavigationStack (iOS 16+)
支持导航功能。
NavigationStack {
NavigationLink("Go to Details", destination: Text("Details View"))
}
data:image/s3,"s3://crabby-images/38f28/38f2852fccc65220a24bd337ab9fbf7963d2d69b" alt=""
2、TabView
选项卡式视图。
TabView {
Text("Home")
.tabItem {
Label("Home", systemImage: "house")
}
Text("Profile")
.tabItem {
Label("Profile", systemImage: "person")
}
}
data:image/s3,"s3://crabby-images/966e4/966e4d82bf55290cb3408345f6c95620f9f658c0" alt=""
动画和修饰
1、ProgressView
显示进度指示器。
ProgressView("Loading...")
data:image/s3,"s3://crabby-images/c389b/c389b817cfce2c4306902a81129daf8378ec1e47" alt=""
2、Alert
弹出警告对话框。
@State private var showAlert = false
Button("Show Alert") {
showAlert = true
}
.alert("Important Message", isPresented: $showAlert) {
Button("OK", role: .cancel) {}
}
data:image/s3,"s3://crabby-images/4a3fa/4a3fa2a9978a9321a26a88269f0d69a04853ad2c" alt=""
3、Sheet
以模态形式呈现视图。
@State private var showSheet = false
Button("Show Sheet") {
showSheet = true
}
.sheet(isPresented: $showSheet) {
Text("This is a sheet.")
}
data:image/s3,"s3://crabby-images/d09b8/d09b829cf8f0731ecd1fcbc7a7c2fd3e5cfb91d7" alt=""
4、Animation
应用动画效果。
@State private var isAnimated = false
Rectangle()
.frame(width: isAnimated ? 200 : 100, height: 100)
.animation(.easeInOut, value: isAnimated)
.onTapGesture {
isAnimated.toggle()
}
data:image/s3,"s3://crabby-images/58c4d/58c4dacc345678c9b29d739de99ef6ecaff7f6ad" alt=""
其他
1、Map (iOS 14+)
显示地图。
import MapKit
struct ContentView: View {
@State private var region = MKCoordinateRegion(
center: CLLocationCoordinate2D(latitude: 35.557267, longitude: 119.631039),
span: MKCoordinateSpan(latitudeDelta: 0.05, longitudeDelta: 0.05)
)
var body: some View {
Map(coordinateRegion: $region)
.edgesIgnoringSafeArea(.all)
}
}
data:image/s3,"s3://crabby-images/39fee/39feeb7fed7056fcac23d12613466bfcf97cfd1d" alt=""
2、VideoPlayer (iOS 14+)
播放视频。
import AVKit
struct ContentView: View {
let player = AVPlayer(url: URL(string: " https://test-videos.co.uk/vids/bigbuckbunny/mp4/h264/720/Big_Buck_Bunny_720_10s_1MB.mp4")!)
var body: some View {
VideoPlayer(player: player)
.frame(height: 200)
}
}
data:image/s3,"s3://crabby-images/c5645/c56457eaf02d7dd8728bde316806dd67df0f446c" alt=""