首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >菜单中的NavigationLink SwiftUI

菜单中的NavigationLink SwiftUI
EN

Stack Overflow用户
提问于 2022-01-07 22:21:32
回答 1查看 274关注 0票数 0

如何以编程方式从在Menu视图上选择SwiftUI中的操作的用户导航到新页面?当我选择一个选项时,我在这里没有导航。

示例代码:

代码语言:javascript
运行
复制
struct MenuView: View {
    @State var oneActive: Bool = false
    @State var twoActive: Bool = false
    var body: some View {
    
        Menu {
            Button {
                oneActive = true
            } label: {
                Text("Option One")
            }
        
            Button {
                twoActive = true
            } label: {
                Text("Option Two")
            }
    
        } label: {
            Image(systemName: "ellipsis")
        }
    
        NavigationLink(destination: Text("Option One View"), isActive: $oneActive) { EmptyView() }
        NavigationLink(destination: Text("Option Two View"), isActive: $twoActive) { EmptyView() }
    }
}

struct ContentView: View {
    var body: some View {
        NavigationView {
            VStack {
                ScrollView {
                    ForEach(0..<100, id: \.self) { index in
                        Text("\(index)")
                    }
                }
            }
            .navigationTitle("TItle")
            .navigationBarTitleDisplayMode(.inline)
            .toolbar {
                ToolbarItem(placement: .navigationBarTrailing) {
                    MenuView()
                }
            }
        }
    }
}
EN

回答 1

Stack Overflow用户

发布于 2022-01-07 23:02:39

工具栏存在于NavigationView层次结构之外,这就是为什么NavigationLinkMenuView中不能工作的原因。相反,您可以将NavigationLinks放在NavigationView中,然后将Bindings发送到MenuView

代码语言:javascript
运行
复制
struct MenuView: View {
    @Binding var oneActive: Bool
    @Binding var twoActive: Bool
    
    var body: some View {
        Menu {
            Button {
                oneActive = true
            } label: {
                Text("Option One")
            }
        
            Button {
                twoActive = true
            } label: {
                Text("Option Two")
            }
    
        } label: {
            Image(systemName: "ellipsis")
        }
    }
}

struct ContentView: View {
    @State private var oneActive: Bool = false
    @State private var twoActive: Bool = false
    
    var body: some View {
        NavigationView {
            VStack {
                NavigationLink(destination: Text("Option One View"), isActive: $oneActive) { EmptyView() }
                NavigationLink(destination: Text("Option Two View"), isActive: $twoActive) { EmptyView() }
                ScrollView {
                    ForEach(0..<100, id: \.self) { index in
                        Text("\(index)")
                    }
                }
            }
            .navigationTitle("TItle")
            .navigationBarTitleDisplayMode(.inline)
            .toolbar {
                ToolbarItem(placement: .navigationBarTrailing) {
                    MenuView(oneActive: $oneActive, twoActive: $twoActive)
                }
            }
        }
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70627789

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档