【Swift UI】非推奨となったNavigationLink(isActive)の対処法

この記事からわかること

  • Swift UINavigationLink(isActive)非推奨になった対処方法
  • navigationDestinationの使い方

index

[open]

\ アプリをリリースしました /

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

NavigationLink(isActive)

公式リファレンス:init(_:destination:isActive:)

画面遷移のタイミングを変数の値が変化した時に実行できるNavigationLink(isActive)が非推奨になっていました。

struct TestNavigationView: View {
    @State  var isActive:Bool = false
    
    var body: some View {
        NavigationView {
            VStack {
                NavigationLink(destination: MyNextView(),
                               isActive: $isActive,
                               label: { EmptyView() })
                
                Button {
                    isActive = true
                } label: {
                    Text("Navigate Button")
                }
            }
            .navigationTitle("Navigation")
        }
    }
}
struct MyNextView: View {
    var body: some View {
        Text("MyNextView")
    }
}

対処法

そもそもNavigationView自体も非推奨に変わっているのでNavigationStackへの置き換えとnavigationDestinationで対処できます。

struct TestNavigationView: View {
    @State  var isPresented:Bool = false
    
    var body: some View {
        NavigationStack {
            VStack {
                Button {
                    isPresented = true
                } label: {
                    Text("Navigate Button")
                }
            }
            .navigationTitle("Navigation")
            .navigationDestination(isPresented: $isPresented) {
                MyNextView()
            }
        }
    }
}

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

New Article

index