【问题标题】:Multiple NavigationLink inside a List using SwiftUI使用 SwiftUI 的列表内的多个 NavigationLink
【发布时间】:2020-08-22 15:36:16
【问题描述】:

我试图在一个结构中包含两个NavigationLinks,我在ListForEach 中用作NavigationLink,但代码不起作用(导航不会发生在View ),代码如下:

struct mainView : View {
    @State var people = [Person(name: "one", family: "1", type: "men"),Person(name: "two", family: "2", type: "women")]
    var body : some View {
        List{
           ForEach(self.people, id:\.self){person in 
               NavigationLink(destination: Text("hi")) {
                 PersonView(person : person)
               }.buttonStyle(BorderlessButtonStyle())
        }
    }
}


struct Person {
    var name : String
    var family : String
    var type : String
}

struct PersonView : View {
    @State var person : Person?
    var body : some View {
      HStack{
        NavigationLink(destination: Text(self.person.name)) {
           Text("this is \(self.person.name) \(self.person.family)")
        }
        NavigationLink(destination: Text(self.person.type)) {
           Text(self.person.type)
        }
      }
    }
}

我在阅读后添加了.buttonStyle ,它可能会有所帮助,但它什么也没做。我还尝试了以下 PersonView :

struct PersonView : View {
@State var person : Person?
@State var goToFirst = false
@State var goToType = false
var body : some View {
   VStack{
      Button(action:{
         self.goToFirst.toggle()
      }){
         Text("this is \(self.person.name) \(self.person.family)")
      }.buttonStyle(BorderlessButtonStyle())
      Button(action:{
         self.goToType.toggle()
      }){
         Text(self.person.type)
      }.buttonStyle(BorderlessButtonStyle())
      NavigationLink(destination: Text(self.person.name), isActive : self.$goToFirst) {
           Text("").frame(width: 0.01, height: 0.01)
      }
      NavigationLink(destination: Text(self.person.type), isActive : self.$goToType) {
           Text("").frame(width: 0.01, height: 0.01)
      }
   }
}

这也不起作用,当我单击单元格上的任意位置时,它会导航到Text("hi") ,当我单击相应区域时,它会导航到正确的View ,我应该怎么做。 重要提示:此视图正在从一个用 NavigationView 包裹的视图导航到

【问题讨论】:

  • 考虑这个解决方案stackoverflow.com/questions/63497247/…。你的情况应该用同样的方法解决。
  • 问题是我希望它是两个单独的“按钮”,用户可以单击而不是像您发送的那样双击单元格

标签: swiftui swiftui-list swiftui-navigationlink


【解决方案1】:

你没有添加navigationView,这就是问题所在。

struct MainView: View {
    @State private var peoples = [Person(name: "one", family: "1", type: "men"),Person(name: "two", family: "2", type: "women")]
    var body: some View {
        NavigationView { //This is important
            List {
                ForEach(self.peoples, id: \.name) { people in
                    NavigationLink(destination: PersonView(person: people)) {
                        Text(people.name)
                    }
                }
            }
            .navigationTitle("Demo")
        }
    }
}

struct Person {
    var name : String
    var family : String
    var type : String
}

struct PersonView : View {
    @State var person : Person?
    var body : some View {
      HStack{
        NavigationLink(destination: Text(self.person.name)) {
           Text("this is \(self.person.name) \(self.person.family)")
        }
        NavigationLink(destination: Text(self.person.type)) {
           Text(self.person.type)
        }
      }
    }
}

【讨论】:

  • 这个视图是从一个封装在一个导航视图中的不同视图导航到的
  • @TheMachineX 最好发布一个简洁但完整的问题示例,因为现在这个人已经努力解决了现在无法使用的答案
  • 100% ,忘记添加了
【解决方案2】:

我认为以下内容可以满足您的要求。代码可以粘贴到空项目中。

一些说明:

List 似乎让事情变得更加困难,所以我用VStack 代替了它。您可能需要用ScrollView 包围它。

此外,正如用户 Asperi 所暗示的那样,当您创建多个 NavigationLink 但围绕随后激活的 EmptyView 时,此方法效果最佳。

struct MainView: View {
    @State var people = [Person(name: "one", family: "1", type: "men"), Person(name: "two", family: "2", type: "women")]

    var body: some View {
        VStack {
            ForEach(self.people, id: \.self) { person in
                PersonView(person: person)
            }
        }
    }
}

struct Person: Hashable {
    var name: String
    var family: String
    var type: String
}

struct PersonView: View {
    let person: Person
    @State private var selection: Int?
    
    var body: some View {
        HStack {
            NavigationLink(
                destination: Text(self.person.name),
                tag: self.person.hashValue + 1,
                selection: self.$selection) {

                EmptyView()
            }
            NavigationLink(
                destination: Text(self.person.type),
                tag: self.person.hashValue + 2,
                selection: self.$selection) {
                
                EmptyView()
            }
            
            Button("this is \(self.person.name) \(self.person.family)") {
                self.selection = self.person.hashValue + 1
            }
            Spacer()
            Button(self.person.type) {
                self.selection = self.person.hashValue + 2
            }.padding()
        }
    }
}

struct ContentView: View {
    var body: some View {
        NavigationView {
            MainView()
        }
    }
}

【讨论】:

  • 问题是特定于列表的,这个答案只是删除了列表。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-04-04
  • 2020-07-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多