mar*_*ram 6 ios swiftui swiftui-alert
我想做类似于下面的代码的事情,当用户点击导航栏项目按钮时它会显示警报。然而,下面的代码不起作用,警报不显示。
我无法将警报修饰符添加到,NavigationView因为我的实际应用程序更复杂,并且它VStack是另一个文件中的视图,而且向同一视图添加多个警报修饰符也不起作用(只有最后一个添加的有效)。
import SwiftUI
struct SOQuestionView: View {
@State private var showAlert1 = false
@State private var showAlert2 = false
var body: some View {
NavigationView {
VStack {
Text("Click button in toolbar")
}
.navigationBarTitle(Text("Title"))
.toolbar {
ToolbarItem(placement: .navigationBarLeading) {
Button(action: {
showAlert1 = true
}) {
Image(systemName: "square.and.arrow.up")
}
.alert(isPresented: $showAlert1) {
Alert(title: Text("Alert 1"))
}
}
ToolbarItem(placement: .navigationBarTrailing) {
Button(action: {
showAlert2 = true
}) {
Image(systemName: "square.and.arrow.up.fill")
}
.alert(isPresented: $showAlert2) {
Alert(title: Text("Alert 2"))
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
解决方案是在工具栏外部使用警报并使用不同的构造函数。使用 Xcode 12.1 / iOS 14.1 进行测试。
struct SOQuestionView: View {
@State private var alertItem: String? // assuming item confirmed to Identifiable
var body: some View {
NavigationView {
VStack {
Text("Click button in toolbar")
}
.navigationBarTitle(Text("Title"))
.toolbar {
ToolbarItem(placement: .navigationBarLeading) {
Button(action: {
alertItem = "Alert 1"
}) {
Image(systemName: "square.and.arrow.up")
}
}
ToolbarItem(placement: .navigationBarTrailing) {
Button(action: {
alertItem = "Alert 2"
}) {
Image(systemName: "square.and.arrow.up.fill")
}
}
}
.alert(item: $alertItem) { item in
Alert(title: Text(item))
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2220 次 |
| 最近记录: |