【SwiftUI】TextFieldをボタンを押すたびに増やす方法!配列でバインディング

この記事からわかること

  • Swift UIボタン押す度にTextField増やす方法
  • TextFieldに配列バインディングするには?

index

[open]

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

みんなの誕生日

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

posted withアプリーチ

Swift UIでボタンを押す度にTextFieldを増やす機能を実装する方法をまとめました。

TextFieldをボタンを押すたびに増やす

Swift UIでボタンを押す度にTextFieldを増やす機能を実装する方法

ボタンを押すたびにTextFieldを増やすには以下のポイントが重要です。

TextField構造体を用いる場合は入力値を保持するための変数を用意しなければいけません。ボタンを増やすたびにTextFieldが増えていく場合は変数を用意する数もフレキシブルである必要があります。なので配列の中の要素と紐付くようにしていきます。

struct ContentView: View {
    @State  var memberArray:[String] = [""]
    var body: some View {
        HStack{
            Button(action: {
                memberArray.append("")
            }, label: {
                Image(systemName: "person.fill.badge.plus")
            }).foregroundColor(.blue).padding(5)
            
            Button(action: {
                memberArray.removeLast()
            }, label: {
                Image(systemName: "person.fill.badge.minus")
            }).foregroundColor(memberArray.count == 1  ? .gray : .red).padding(5).disabled(memberArray.count == 1)
        }
        ForEach(memberArray.indices, id: \.self) { i in
            TextField("メンバー\(i + 1)", text: $memberArray[i]).frame(width: 200).padding(5)
        }
    }
}

TextFieldの追加はバインディングしている配列内の要素の追加で実装できます。ここではボタンを押されるたびに空の要素をappendメソッドで追加しています。

memberArray.append("")

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

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

私がSwift UI学習に使用した参考書

searchbox

スポンサー

ProFile

ame

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

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

自作iOSアプリ

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

mapping

自分だけの地図を作ろう!-mapping-

無料posted withアプリーチ

割り勘アプリ-bill-

旅行におすすめ!
割り勘アプリ-bill-

無料posted withアプリーチ

Imakoko

現在地を取得するアプリ!Imakoko

無料posted withアプリーチ

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

Remind-シンプル通知アプリ-

シンプル通知アプリ-Remind-

無料posted withアプリーチ

CLIPURL

好きな記事をクリップしよう!-CLIPURL-

無料posted withアプリーチ

記録カレンダー

続けたを可視化できるアプリ!記録カレンダー

無料posted withアプリーチ

CART-共有できるお買い物リスト-

CART-共有できるお買い物リスト-

無料posted withアプリーチ

QuickPressPanel

早押しゲーム-QuickPressPanel-

無料posted withアプリーチ

貸し借り管理アプリ

友達とのお金の管理-貸し借り管理アプリ-

無料posted withアプリーチ

みんなの誕生日

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

posted withアプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

New Article

index