0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【SwiftUI】TextFieldビューを基本から学ぶ

Last updated at Posted at 2024-06-02

SwiftUIのテキストフィールド

TextFieldはコントロール系のSwiftUIビューです。
アプリケーションの画面に「文字列を編集する」ためのテキストフィールド・インターフェースを表示します。

Swiftを基礎から学ぶには
自著、工学社より発売中の「まるごと分かるSwiftプログラミング」をお勧めします。変数、関数、フロー制御構文、データ構造はもちろん、構造体からクロージャ、エクステンション、プロトコル、クロージャまでを基礎からわかりやすく解説しています。
また、Swiftプログラミングを基礎から動画で学びたい方には、Udemyコース「今日からはじめるプログラミング」をお勧めします。

TextFieldの概要

テキストフィールドには、ラベルと「ステート値のバインディング」が含まれます。
ステート値が文字列の場合、テキストフィールドはユーザー入力するに合わせて値を継続的に更新するか、フィールドのテキストを編集します。
ステート値が文字列ではない場合、ユーザーが(リターンキーを押すなどして)編集をコミットしたタイミングで、ステート値を更新します。

テキストフィールドのバインド値は、必ずしも文字列である必要はありません。
イニシャライザでformat引数を指定すると、テキストフィールドを非文字列型の値にバインドできます。
そして、FormatStyleを使用して、入力されたテキストを「バインドされた型のインスタンス」に変換できます。

テキストフィールドのプロンプト

テキストフィールドのプロンプトは、「入力すべきテキスト内容」をユーザーに示唆します。
テキストフィールドのプロンプトとラベルが「いつ、どこに表示されるか」は、各テキストフィールドのスタイルによって決定されます。
例えば、macOSのフォームでは、常にフィールド前端にラベルを配置し、プロンプトも利用可能な場合はフィールド自体のプレースホルダとして使用します。
iOSの同じ状況では、テキストフィールドのイニシャライザにプロンプトを指定した場合に、プロンプトをプレースホルダとして使用します。

下の画像は、2つのテキストフィールドを持つフォームの例です。
それぞれのフィールドが「Required」のプロンプトとラベルを提供します。

スクリーンショット 2024-06-02 18.49.36.png

フォーム内のテキストフィールド
Form {
    TextField(text: $username, prompt: Text("Required")) {
        Text("Username")
    }
    SecureField(text: $password, prompt: Text("Required")) {
        Text("Password")
    }
}

テキストフィールドのスタイル

SwiftUIのテキストフィールドは、プラットフォームに最適化された外観と動作を反映した標準スタイルを提供します。
標準スタイルは、そのテキストフィールドが「特別なスタイルでテキストフィールドを表示するコンテナ内にあるか」も考慮します。
その上で、textFieldStyle(_:)モディファイアを使用すると、テキストフィールドの外観と操作性をカスタマイズして、TextFieldStyleのインスタンスを渡すことができます。

下の画像は、2つのテキストフィールドにroundedBorderスタイルを適用した例です。

スクリーンショット 2024-06-02 18.50.43.png

境界線があるテキストフィールドのスタイル
VStack {
    TextField(
        "Given Name",
        text: $givenName
    )
    .disableAutocorrection(true)
    TextField(
        "Family Name",
        text: $familyName
    )
    .disableAutocorrection(true)
}
.textFieldStyle(.roundedBorder)

コード

TextFieldビューは、テキストを入力できるボックスです。
テキストフィールドは、文字列のステート値を変更します。

イニシャライザ

// テキストラベルを含むテキストフィールドを作成する(ラベルはテキスト)
init(
    _ titleKey: LocalizedStringKey,
    text: Binding<String>
)
// テキストラベルを含むテキストフィールドを作成する(ラベルはテキスト)
// promptは、ユーザーに「テキストフィールドで何を入力するか」を示すガイダンス
init(
    _ titleKey: LocalizedStringKey,
    text: Binding<String>,
    prompt: Text?
)

実践

スクリーンショット 2024-06-02 23.29.07.png

  1. テキストフィールドで入力した文字列を格納するための、新しいステート変数を宣言します。

  2. ビューのbodyTextFieldを配置します。
    TextFieldのイニシャライザでは、text引数にステート変数のバインディングを渡します。
    これによって、TextFieldでの入力でステート値が変更されると、SwiftUIはビューを更新します。

  3. .onSubmitモディファイアでは、クロージャを使用して「ユーザーがリターンをタップしたときに実行するコードを指定します。
    空の文字列が入力されないようにするには、if文を追加します。

  4. テキストフィールドでキーボードのオートコレクトが不要な場合は、モディファイアを使用してオフにできます。

import SwiftUI

struct ContentView: View {
    @State private var message = ""
    
    var body: some View {
        VStack {
            TextField("あいさつをどうぞ", text: $message)
                .autocorrectionDisabled()
                .onSubmit {
                    if !message.isEmpty {
                        message = ""
                    }
                }
            Text(message)
                .font(.headline)
        }
        .padding()
    }
}

iOSキーボードでテキストフィールドがどのように機能するかを確認するには、シミュレータで「Product > Run to run your app」を選択します。
場合によっては、テキストフィールドでのキーボードを表示するために、シミュレータで「I/O > Keyboard > Toggle Software Keyboard」を選択する必要があります。

参考

Form
TextField
Develop in Swift Tutorials

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?