質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.31%
Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

0回答

268閲覧

バリデーションチェックエラー後にセレクトボックスの情報を保持したままリダイレクトしたい

user-name1

総合スコア13

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

0クリップ

投稿2023/03/28 13:30

編集2023/03/29 10:08

実現したいこと(具体的な例)

以下のようなバリデーションで再描画したいです
イメージ説明

現状

イメージ説明

→「Name」のセレクトボックスの値がクリアされる
※「Team」で選択した値に紐づくNameをajaxで作成し設定

該当のソースコード

現在のexportメソッドでバリデーションチェックを行う処理

php

1class ExportController extends Controller{ 2 3public function export(Request $request) 4 { 5 $validator = $this->validation($request); 6 if ($validator->fails()) { 7 return redirect('/dashboard/export') 8 ->withErrors($validator) 9 ->withInput(); 10 } 11 12//以下でエクスポート本処理(省略) 13 } 14}

javascript

1$.ajax({ 2 url: "/dashboard/exportajax", 3 type: "POST", 4 data: { 5 team_id: selectedTeamId, 6 }, 7 dataType: "json", 8 }) 9 .done(function (data) { 10 $("#namePullDownList option").remove(); 11 12 // 初期表示時(select...)の場合 13 if (data == 0) { 14 $("#namePullDownList").prop("disabled", true); 15 $("#namePullDownList").append( 16 $("<option>").text("").attr("value", 0) 17 ); 18 } else { 19 $("#namePullDownList").prop("disabled", false); 20 $("#namePullDownList").append( 21 $("<option>").text("all").attr("value", 0) 22 ); 23 $.each(data, function (key, value) { 24 $("#namePullDownList").append( 25 $("<option>") 26 .val(value.user_id) 27 .text(value.first_name + value.last_name) 28 ); 29 }); 30 } 31 }) 32 .fail(function () { 33 console.log("NG"); 34 });

補足情報

View側では以下のように再描画時のデータを設定しています
※開始日のバリデーション部分のみ抜粋

php

1<div class="col-sm-6 ps-0"> 2 <label for="date" class="p-0 form-label">{{ __('StartDate') }}</label> 3 <input id="startDate" type="date" class="form-control" name="start_date" value="{{ old('start_date') }}"> 4 {{-- バリデーションメッセージ --}} 5 @foreach ($errors->get('start_date') as $error) 6 <span class="p-0 text-danger">{{ $error }}</span> 7 @endforeach 8</div> 9

その他(バージョン)

■OS Mac ■バージョン PHP:8.0.26 Laravel:9.45.1

投稿者コメント

足りない情報などあれば追記します。
お力を貸していただけますと幸いです、よろしくおねがいします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2023/03/29 04:08

もっと要件を絞ったほうが課題解決につながると思います
user-name1

2023/03/29 10:09

ご教示いただきありがとうございます。 不要文言を削除したので、もし可能でしたら内容を確認いただきご教示いただければと思います
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.31%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問