SwiftUI的导航界面的嵌套问题

在SwiftUI中,有一种控件叫做NavigationView。这种控件是一个容器,里面通常包含多个NavigationLink,用于点击后切换到下一个界面。

这样的切换,根据代码书写方式不同,有可能是整个页面切换,也可能是页面的一部分切换。

先给出代码和效果。

代码包括三个文件:

  1. 主程序
swift 复制代码
import SwiftUI

@main
struct MyApp: App {
    var body: some Scene {
        WindowGroup {
            ContentView()
        }
    }
}
  1. ContentView(首页)
swift 复制代码
import SwiftUI

struct ContentView: View {
    var body: some View {
        NavigationView(content: {
            NavigationLink(destination: NavigateView1()) 
            { Text("Navigate 1") }
        })
    }
}

#Preview {
    ContentView()
}
  1. NavigateView1(下一页)
swift 复制代码
import SwiftUI

struct NavigateView1: View {
    var body: some View {
        NavigationView(content: {
            NavigationLink(destination: Text("Destination")) { Text("Navigate nested") }
        })
        NavigationLink(destination: Text("Destination")){
            Text("Navigate not nested")
        }
    }
}

#Preview {
    NavigateView1()
}

效果:

第一张图,点击了Navigate nested,然后最顶上的左箭头仍然保留,下方的Navigate not nested仍然保留。中间那个Navigate nested占用的一大片区域跳转到了新的Destination页面,上方有另一个箭头。从最右的图中可以看出,这个Destination界面有两个左箭头,也就是说它把两层目录嵌套在了同一张屏幕上。

第二种图,点击了Navigate not nested,整个屏幕都切换到了Destination页面。

之所以有这样的区别,原因在于第三块Swift代码,即NavigateView1的代码。

Navigation1里有两个NavigationLink,其中第一个是嵌在NavigationView里的,另一个是独立的。前面说到NavigationView是一个容器,所以当它里面的NavigationLink被点击时,只有容器里的内容才切换至新页面,容器外不影响。但不在NavigationView容器里的NavigationLink被点击时,整个页面都切换。

相关推荐
.千余1 小时前
【C++】C++ map 与 multimap 完全指南:键值对容器详解
开发语言·c++·笔记·学习·其他
牢姐与蒯1 小时前
c++数据结构之c++11(三)
开发语言·c++
hoiii1871 小时前
17自由度铁道车辆横向动力学MATLAB程序
开发语言·matlab
大蚂蚁2号1 小时前
Python 项目架构深度解析:从混乱到清晰
开发语言·python·架构
yaoxin52112310 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
凡人叶枫10 小时前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
学逆向的10 小时前
C++纯虚函数
开发语言·c++·网络安全
程序员二叉11 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉11 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc