カテゴリ: Laravel 更新日: 2025/12/09

Laravelでセレクトボックスを生成・バインドする方法(選択肢の動的生成)

Laravelでセレクトボックスを生成・バインドする方法(選択肢の動的生成)
Laravelでセレクトボックスを生成・バインドする方法(選択肢の動的生成)

先生と生徒の会話形式で理解しよう

生徒

「先生、Laravelでセレクトボックスを作りたいんですけど、選択肢を動的に生成する方法はありますか?」

先生

「もちろんできます。データベースの情報や配列から動的に選択肢を作って、Bladeテンプレートで表示する方法があります。」

生徒

「動的に作ると、ユーザーが選んだ値をどうやって取得するんですか?」

先生

「ControllerでRequestオブジェクトを使って、input()で受け取ります。選択肢の値がそのまま取得できるので簡単です。」

1. Bladeでセレクトボックスを作る

1. Bladeでセレクトボックスを作る
1. Bladeでセレクトボックスを作る

まずは静的なセレクトボックスの例です。セレクトボックスとは、ユーザーが複数の選択肢から1つを選べるフォーム部品です。


<form action="{{ route('form.submit') }}" method="POST">
    @csrf
    <select name="fruit" class="form-select">
        <option value="">選択してください</option>
        <option value="りんご" {{ old('fruit') == 'りんご' ? 'selected' : '' }}>りんご</option>
        <option value="みかん" {{ old('fruit') == 'みかん' ? 'selected' : '' }}>みかん</option>
        <option value="バナナ" {{ old('fruit') == 'バナナ' ? 'selected' : '' }}>バナナ</option>
    </select>
    <button type="submit" class="btn btn-primary mt-2">送信</button>
</form>

ここでold('fruit')を使うことで、バリデーションエラー時にユーザーの選択を保持できます。

2. 配列やデータベースから動的に選択肢を生成する

2. 配列やデータベースから動的に選択肢を生成する
2. 配列やデータベースから動的に選択肢を生成する

動的生成では、配列やデータベースのデータをループで回して


@php
$fruits = ['りんご', 'みかん', 'バナナ', 'ぶどう'];
@endphp

<select name="fruit" class="form-select">
    <option value="">選択してください</option>
    @foreach ($fruits as $fruit)
        <option value="{{ $fruit }}" {{ old('fruit') == $fruit ? 'selected' : '' }}>{{ $fruit }}</option>
    @endforeach
</select>

ループ処理@foreachを使って、配列の要素を1つずつ

3. Controllerで選択値を受け取る

3. Controllerで選択値を受け取る
3. Controllerで選択値を受け取る

ControllerではRequestオブジェクトを使って値を受け取ります。


public function submit(Request $request)
{
    $request->validate([
        'fruit' => 'required|string',
    ]);

    $selectedFruit = $request->input('fruit'); // 選択された値を取得
}

バリデーションを行うことで、未選択の場合にエラーを返すこともできます。

4. データベースから選択肢を生成する場合

4. データベースから選択肢を生成する場合
4. データベースから選択肢を生成する場合

例えば、fruitsテーブルに登録されている果物をセレクトボックスに表示する場合です。


// Controller
public function create()
{
    $fruits = \App\Models\Fruit::all(); // データベースから取得
    return view('form.create', compact('fruits'));
}

<select name="fruit" class="form-select">
    <option value="">選択してください</option>
    @foreach ($fruits as $fruit)
        <option value="{{ $fruit->id }}" {{ old('fruit') == $fruit->id ? 'selected' : '' }}>
            {{ $fruit->name }}
        </option>
    @endforeach
</select>

これでデータベースの内容が自動でセレクトボックスに反映されます。

5. 選択肢生成のポイント

5. 選択肢生成のポイント
5. 選択肢生成のポイント
  • 静的・動的の両方でセレクトボックスを作れる
  • 動的生成は配列やデータベースをループで
  • バリデーション後の保持はold()で簡単に実装
  • ControllerでRequestを使って選択値を取得
  • 未選択時のバリデーションを設定してユーザーの入力ミスを防ぐ
カテゴリの一覧へ
新着記事
New1
Laravel
LaravelでAPIのレスポンスをテストする方法を完全解説!assertJsonで初心者も安心
New2
CodeIgniter
CodeIgniterでRESTful API開発!初心者でもわかる全体構成ガイド
New3
Symfony
Symfonyのコントローラとは?作成・構造・役割を初心者向けにやさしく解説!
New4
Symfony
Symfonyでバリデーションメッセージを多言語対応する方法!初心者でもわかる国際化の基本
人気記事
No.1
Java&Spring記事人気No1
Laravel
Laravelで動的パラメータをルートに渡す方法!初心者にもやさしいルートパラメータの使い方入門
No.2
Java&Spring記事人気No2
Laravel
Laravelのシングルアクションコントローラとは?使い方と利点
No.3
Java&Spring記事人気No3
Symfony
Symfonyの依存性注入(DI)とは?コンストラクタでの注入方法を初心者向けに徹底解説
No.4
Java&Spring記事人気No4
Laravel
Laravelでキャッシュを使う方法(ファイル・Redis・Memcached)
No.5
Java&Spring記事人気No5
Laravel
LaravelのBlade構文まとめ!@if @foreach など基本ディレクティブ解説
No.6
Java&Spring記事人気No6
Laravel
Laravelのマイグレーション履歴を確認する方法を徹底解説!migrate:statusの使い方
No.7
Java&Spring記事人気No7
Laravel
Laravelで名前付きルートを設定する方法!初心者でもわかるroute()関数の使い方
No.8
Java&Spring記事人気No8
Symfony
Symfonyとは?PHPの堅牢なフレームワークの特徴と活用シーン