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

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

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

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Laravel

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

PHP

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

1回答

1440閲覧

jqueryのその場編集を利用してボタンを押した時に値が変更されるようにしたい

eggb4by

総合スコア0

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Laravel

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

PHP

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2020/05/11 03:38

前提・実現したいこと

現在Laravel,phpを勉強中で勉強の一環としてタスクリストを作成しています。
追加したタスクリストの名前をタイトルで記述した内容で実装したいと考えております。
更新ボタンを押さずにタスク名を書き換えられるのは確認済みです。
タスク名を書き換えて更新ボタンを押した際に以下のエラーメッセージが発生しました。

発生している問題・エラーメッセージ

SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'name' cannot be null (SQL: update `tasks` set `name` = ?, `tasks`.`updated_at` = 2020-05-11 03:01:10 where `id` = 13)

該当のソースコード

html

1<!-- テーブル本体 --> 2 <tbody class="row"> 3 @foreach ($tasks as $task) 4 <tr> 5 <td class="table-text"> 6 <dl> 7 <dt>タスク名</dt> 8 <dd>{{ $task->name }}</dd> 9 </dl> 10 </td> 11 <td style="text-align: right; padding-top: 28px"> 12 <!-- タスク名編集 --> 13 <form action="{{ url('task/' . $task->id) }}" method="POST"> 14 15 @csrf 16 @method('PUT') 17 18 <button type="submit" class="btn btn-put"> 19 <i class="fas fa-sync-alt"></i> 更新 20 </button> 21 </form> 22 </td>

jquery

1 <script> 2 $(function($){ 3 $('dd').click(function(){ 4 if(!$(this).hasClass('on')){ 5 $(this).addClass('on'); 6 var txt = $(this).text(); 7 $(this).html('<input type="text" value="'+txt+'" />'); 8 } 9 }); 10 }); 11 </script>

php

1 /** 2 * タスク名変更 3 */ 4 Route::put('/task/{task}', function ($id , Request $request) { 5 $task = Task::find($id); 6 $task->name = $request->name; 7 $task->save(); 8 return redirect('/'); 9 }); 10

画像は現在の状態になります

試したこと

その場編集を実装する前はinputタグでテキストボックスを作りそこに変更したい名前を入力して更新ボタンを押すと値が書き換わる
仕様にしておりこちらは上手くいきました。phpのコードはこの時のままにしてあります。
変更した点はテキストボックスを消してjqueryを追加しました。

補足情報

勉強を始めたばかりで説明が分かりづらい部分が多々あるかと思いますがご教授頂けると幸いです。

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

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

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

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

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

guest

回答1

0

Column 'name' cannot be null

ですから、「nameカラムはnullにできない」
ということですね。

dd()で確認して見ると分かるかと思いますが、おそらく$request->nameがnullなのでしょう。

ちなみに、inputにname属性を指定していない場合、送信されません。
つまり、名無しさんになるわけですね。

$(this).html('<input type="text" value="'+txt+'" />');

投稿2020/05/11 03:51

m.ts10806

総合スコア80875

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

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

eggb4by

2020/05/11 04:23

回答有難うございます。 inputにname属性を指定してあげましたが同じようなエラーが出ました。 私が未熟で回答に対してきちんと読み取れていないだけかもしれませんがこの修正だけでは 不十分なのでしょうか? 重ね重ね申し訳ありませんがご教授頂けると助かります。
m.ts10806

2020/05/11 04:32

回答にあるように$request->nameの内容を確認してみましたか? あとは$request->nameでなく固定値で文字列入れてみて確かめてみてください。問題の切り分けです。
eggb4by

2020/05/11 04:49

すみませんでした。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問