首页 > 解决方案 > SwiftUI 中视图主体的差异

问题描述

我有一个菜单列表

let muscleEtfs = Menu(name:"MuscleETFs",  image:"image", destination: .muscleETFs)

let menus: [Menu] = [home, marketTrend, indexes, sectors, stockAnalysis, backtest, screener, myPortfolio, watchList, muscleStocks, muscleEtfs]

我的目标是有条件地更改 SwiftUI 中 NavigationLink 的目的地。任何人都可以向我解释为什么开关盒不起作用但如果起作用。

let muscleEtfs = Menu(name:"MuscleETFs",  image:"image", destination: .muscleETFs)

    var body: some View {
        let menus: [Menu] = [home, marketTrend, indexes, sectors, stockAnalysis, backtest, screener, myPortfolio, watchList, muscleStocks, muscleEtfs]

        return List {
            ForEach(menus) { menu in

                // This does not work
                switch menu.destination {
                case .news:
                    NavigationLink(
                            destination: HomeNewsView(menu: menu)
                    )
                    {
                        Text("\(menu.name)")
                    }
                default:
                    NavigationLink(
                            destination: HomeNewsView(menu: menu)
                    )
                    {
                        Text("\(menu.name)")
                    }

                }

                // This does
                if menu.destination == .news   {
                    NavigationLink(
                            destination: HomeNewsView(menu: menu)
                    )
                    {
                        Text("\(menu.name)")
                    }
                }
            }
        }

使用 switch 条件会在 Xcode 上引发编译错误

包含控制流语句的闭包不能与函数构建器“ViewBuilder”一起使用

标签: xcodeswiftuiswiftui-navigationlink

解决方案


这行得通,记住返回类型 AnyView 或 View 将不起作用。

func destinationView(menu: Menu) -> 一些视图 {

        switch menu.destination {
        case .news:
            return NavigationLink(
                    destination: HomeNewsView(menu: menu)
            )
            {
                Text("\(menu.name)")
            }
        default:
            return NavigationLink(
                    destination: HomeNewsView(menu: menu)
            )
            {
                Text("\(menu.name)")
            }
        }

    }

推荐阅读