Laravelの編集画面のプルダウンでDBやoldでの値の保持をする場合はどのように書けばいいのでしょうか?
現在以下のようにプルダウンを書いていますが、
編集画面に遷移したときに、
・DBの値はselectedされて初期表示される
・プルダウンを変更して、バリデーションに引っかかったときに、oldで値が保持されなくて、初期表示のDBの値になる
<select class="form-control{{ $errors->has('post_id') ? ' is-invalid' : '' }}" name="post_id" id="post-code"> <option></option> @foreach ($posts as $post) @if (($post->post_id == $user->post_id) || $post->post_id === (int)old('post_id')) <option value="{{ old('post_id', $post->post_id) }}" selected>{{ old('post_name', $post->post_name) }}</option> @else <option value="{{ $post->post_id }}">{{ $post->post_name }}</option> @endif @endforeach </select>
原因を調べてみると、プルダウン変更してバリデーションに引っかかったときに本来は1つselectedになっていて欲しいが、2つのoptionにselectedがついてる。
なので、編集画面のプルダウンを作成する場合、
・初期表示はDBに紐づいた値が表示
・プルダウン変更してバリデーションに引っかかった場合は、oldの値をプルダウンに表示
このように書くにはどうすればいいでしょうか?
<select class="form-control{{ $errors->has('post_id') ? ' is-invalid' : '' }}" name="post_id" id="post-code"> <option></option> @foreach ($posts as $post) @if ($post->post_id == $user->post_id) <option value="{{ $post->post_id) }}" selected>{{ $post->post_name) }}</option> @else <option value="{{ $post->post_id }}">{{ $post->post_name }}</option> @endif @endforeach </select>
こんな感じに書いてみたら、初期表示はDBの値を選択状態にしてくれるのですが、プルダウンを変更してバリデーションに引っかかったときは、前に選択した値を表示ではなくDBの値を表示になります。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/11/12 10:13