SwiftUI学习-视图切换方式

视图切换方式

状态

通过当前的状态(e.g. @State@StateObject@ObservedObject...)来决定当前的SwiftUI View展示与否,且自带有动画效果。示例如下

dart 复制代码
struct ContentView: View {
  @State var show = true
  var body: some View {
    
    VStack {
      Button("Show Text") {
        show.toggle()
        print(show)
      }
      
      if show {
        Text("Show")
      }
    }
  }
}

Sheet

隐式地启动/嵌入新的VC,类似于iOS开发中的presentViewController,SwiftUI提供如下两个API。

less 复制代码
public func sheet<Item, Content>(item: Binding<Item?>,
                                 onDismiss: (() -> Void)? = nil,
                                 @ViewBuilder content: @escaping (Item) -> Content)
-> some View where Item : Identifiable, Content : View

public func fullScreenCover<Content>(isPresented: Binding<Bool>,
                                     onDismiss: (() -> Void)? = nil,
                                     @ViewBuilder content: @escaping () -> Content)
-> some View where Content : View

调用示例如下

dart 复制代码
struct ContentView: View {
  @State var show = false
  
    var body: some View {
      Button("Show Text") {
          show.toggle()
          print(show)
      }.sheet(isPresented: $show) {
        Button("Hide Text") {
            show.toggle()
            print(show)
        }
      }
    }
}

表示视图栈的View,该View表示导航层次结构中可见的路径。使用NavigationView创建一个基于导航的应用程序,用户可以在其中遍历视图集合。 用户通过选择你提供的NavigationLink导航到目标视图。在iPadOS和macOS上,目标内容将在下一栏中显示。 其他平台将一个新的View推入堆栈,并通过平台特定的控件(如后退按钮或滑动手势)从堆栈中删除项目。

在macOS上显示多列导航视图,在iOS上显示视图堆栈的图表(类比的UINavigationController)

示例如下:

css 复制代码
struct ContentView: View {
    var body: some View {
      NavigationView {
        NavigationLink {
          Text("Destination")
        } label: {
          Text("Show Text")
        }
      }
    }
}
相关推荐
大熊猫侯佩2 天前
iOS 26 仅需几行代码让 SwiftUI 7 液态玻璃界面焕发新春
前端·swiftui·apple
东坡肘子7 天前
从开放平台到受控生态:谷歌宣布 Android 开发者验证政策 | 肘子的 Swift 周报 #0101
android·swiftui·swift
HarderCoder7 天前
深入理解 SwiftUI 的 Structural Identity:为什么“换个条件分支”就会丢状态?
swiftui·swift
YungFan8 天前
Swift 6.2 新特性
swiftui·swift
大熊猫侯佩11 天前
当液态玻璃计划遭遇反叛者:一场 iOS 26 界面的暗战
swiftui·xcode·apple
雪糕吖12 天前
SwiftUI 自定义 Shape:实现顶部圆角矩形 RoundedTopRectangle
ios·swiftui
东坡肘子14 天前
写给这段旅程,也写给未来的自己 | 肘子的 Swift 周报 #0100
swiftui·swift·apple
大熊猫侯佩19 天前
SwiftUI 三阵诀:杨过绝情谷悟 “视图布阵” 之道
swiftui·swift·apple
东坡肘子21 天前
未来将至:人形机器人运动会 | 肘子的 Swift 周报 #099
swiftui·swift·apple
吴Wu涛涛涛涛涛Tao24 天前
基于TCA构建Instagram克隆:SwiftUI状态管理的艺术
ios·swiftui