繁体   English   中英

在SwiftUI中点击ActionSheet.Button后如何呈现视图?

[英]How to present a View after tapping an ActionSheet.Button in SwiftUI?

我一直在玩SwiftUI,并为这个简单的东西而感到困惑。 基本上,我试图在点击ActionSheet.Button之后触发模式。 到目前为止,这是我的代码:

struct SomePage: View {
    @State var showSheet = false

    var body: some View {
        Button(action: {
            self.showSheet = true
        }) { 
            Text("Show ation sheet") 
        }.presentation(sheet)
    }

    private var sheet: ActionSheet? {
        let button = ActionSheet.Button.default(Text("Button") {
             self.showSheet = false
             // what now??
        }
        let action = ActionSheet(title: Text("Title"),
                                 message: nil,
                                 buttons: [button])
        return showSheet ? action : nil
    }

    // This is the modal I'm trying to present 
    // after tapping on the action sheet button
    private var modal: Modal {
        return Modal(SomePage())
    }
}

我尝试将第二个presentation处理程序添加到按钮并切换showModal属性,但是显然调试器抱怨在第一个模式表示仍在显示时尝试第二个模式表示。

有人对如何进行这项工作有想法吗?

您离它并不远。

添加另一个@State来处理模式的表示。

struct ContentView: View {

    @State var showSheet = false
    @State var showModal = false

    var body: some View {
        Button(action: {
            self.showSheet = true
        }) {
            Text("Show action sheet")
        }
        .actionSheet(isPresented: $showSheet, content: actionSheet)
        .sheet(isPresented: $showModal, content: { Text("Modal") })
    }

    private func actionSheet() -> ActionSheet {
        let button = ActionSheet.Button.default(Text("Show modal")) {
            self.showSheet = false
            self.showModal = true
        }
        let actionSheet = ActionSheet(title: Text("Action Sheet"),
                                      message: nil,
                                      buttons: [button])
        return actionSheet
    }

}

结果

在此处输入图片说明

更新了Xcode 11 beta 5

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM