首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SwiftUI ViewModifier不作为NavigationLink工作

SwiftUI ViewModifier不作为NavigationLink工作
EN

Stack Overflow用户
提问于 2022-06-12 16:47:22
回答 1查看 143关注 0票数 2

我有以下ViewModifier,但它不工作:

代码语言:javascript
复制
import SwiftUI

struct NavLink: ViewModifier {
    let title: String
    
    func body(content: Content) -> some View {
        NavigationLink(destination: content) {
            Text(title)
        }
    }
}

extension View {
    func navLink(title: String) -> some View {
        modifier(NavLink(title: title))
    }
}

如果我这样说的话:

代码语言:javascript
复制
import SwiftUI

struct MainScreen: View {
    var body: some View {
        NavigationStack() {
            VStack {
                // This does not work
                NavStackScreen()
                    .navLink(title: "Nav Stack")

                // But this does
                Helper.linked(to: NavStackScreen(), title: "Nav Stack 2")
            }
        }
    }
}

struct Helper {
    static func linked(to destination: some View, title: String) -> some View {
        NavigationLink(destination: destination) {
            Text(title)
        }
    }
}

如果点击,它将创建链接并将一个新视图推送到屏幕上;但是,NavStackScreen的内容不显示,只有一个空屏幕。对发生了什么事有什么想法吗?

供参考的NavStackScreen内容:

代码语言:javascript
复制
struct NavStackScreen: View {
    var body: some View {
        Text("Nav Stack Screen")
            .font(.title)
            .navigationTitle("Navigation Stack")
    }
}

如果我在帮助器结构中使用静态帮助函数,那么它将正确工作:

代码语言:javascript
复制
    static func linked(to destination: some View, title: String) -> some View {
        NavigationLink(destination: destination) {
            Text(title)
        }
    }

我添加了MainView的完整代码以供参考,并以更详细的方式更新了示例,以便于复制。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-15 14:43:40

修饰符不能工作,因为content参数不是要修改的实际视图,而是一个代理:

content是视图的代理,该视图将由Self表示修饰符。

参考文献

这是对修饰符的快速调试所显示的:

代码语言:javascript
复制
(lldb) po content
SwiftUI._ViewModifier_Content<SwiftUIApp.NavLink>()

由于代理是SwiftUI的内部类型,我们无法确定为什么NavigationLink不能与它一起工作。

解决方法是跳过修饰符,只在View上添加扩展

代码语言:javascript
复制
extension View {
    func navLink(title: String) -> some View {
        NavigationLink(destination: content) {
            Text(title)
        }
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72594145

复制
相关文章

相似问题

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