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被点击时,整个页面都切换。

相关推荐
C+-C资深大佬5 分钟前
python while循环
服务器·开发语言·python
Tian_Hang5 分钟前
eclipse ditto 学习笔记
运维·服务器·开发语言·javascript·3d
星夜夏空9916 分钟前
C++学习(2) —— 类与对象基础
开发语言·c++·学习
倒流时光三十年37 分钟前
Java 内存模型(JMM)通俗解释
java·开发语言
码兄科技1 小时前
Java AI智能体开发实战:从零构建企业级智能应用指南
java·开发语言·人工智能
zh路西法1 小时前
【现代控制理论与卡尔曼滤波】从状态空间到Python仿真实现
开发语言·python
Evand J1 小时前
【论文复现】MATLAB例程,存在测距误差的WSN无锚点分布式自定位,《WSN中存在测距误差的无锚点分布式自定位方法》
开发语言·分布式·matlab·定位·导航·wsn
techdashen2 小时前
kTLS 进入 rustls 组织:把 TLS 的数据面交给内核
开发语言·php
Lhappy嘻嘻2 小时前
Java 并发编程(六)|并发进阶高频:CAS、锁升级
java·开发语言
techdashen2 小时前
Arborium:把 tree-sitter 语法高亮打包成 Rust 文档生态的基础设施
开发语言·后端·rust