🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

1回答

2173閲覧

show.html.erbでフォームに書いたコメントを同じshow.html.erbに表示させるようにしたいです

sugiboo_ayumu

総合スコア0

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/02/07 15:41

コメントの投稿ボタンを押すとエラーが出てしまいます

ruby on railsでコメント機能を実装しようとしています。
コメントフォームにコメントを入力し、「コメントする」をクリックするとエラーが出てしまいます。

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

ActionController::UrlGenerationError in CommentsController#create No route matches {:action=>"show", :controller=>"items", :item_id=>"9"}, missing required keys: [:id] ``` エラーメッセージ ``` Extracted source (around line #4):   2 def create   3  Comment.create(comment_params)   4  redirect_to item_path # コメントと結びつく商品の詳細画面に遷移する    5 end   6   7 private ``` ソースコード ``` comments_controller.rb class CommentsController < ApplicationController def create Comment.create(comment_params) redirect_to item_path # コメントと結びつく商品の詳細画面に遷移する end private def comment_params params.require(:comment).permit(:text).merge(user_id: current_user.id, item_id: params[:item_id]) end end ``` ``` items_controller.rb def show @comment = Comment.new @comments = @item.comments.includes(:user) end ``` ``` show.html.erb <th class="detail-item">コメント</th> <td class="detail-value"> <div id='messages'> <% @comments.reverse_each do |comment| %> <br><%= comment.text %> <% end %> </div> </td> <div class="comment-box"> <%= form_with model: [@item, @comment], url: item_comments_path(@item), local: true do |f| %><%# rails routesで確認 %> <%= f.text_field :text ,class: "comment-text"%> <p class="comment-warn"> 相手のことを考え丁寧なコメントを心がけましょう。 <br> 不快な言葉遣いなどは利用制限や退会処分となることがあります。 </p> <%= f.submit "コメントする" ,class:"comment-btn" %><%= image_tag "comment.png" ,class:"comment-flag-icon" ,width:"20",height:"25" %> <% end %> </div> <div class="links"> <a href="#" class="change-item-btn"> < 前の商品 </a> <a href="#" class="change-item-btn"> 後ろの商品 > </a> </div> <a href="#" class='another-item'><%= @item.category.name %>をもっと見る</a> </div> ``` ### 試したこと 入力したコメントをcommentテーブルに保存し、それをitemコントローラーのshowアクションに渡して表示させようとしています。 commentモデルのリダイレクト先のコードが間違っているかと思います。(リダイレクト先はshowにしたいです。) redirect_to root_pathにするときちんと一覧ページに飛んでくれます。 rails routesをみるとshowに飛ぶにはitem_pathになっています。 itemのidが無いのかなと思い、item_pathに続いて@comments.item.idなど入力してみました。 ### 補足情報(FW/ツールのバージョンなど) ここにより詳細な情報を記載してください。

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

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

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

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

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

neenonw89

2024/05/09 09:36 編集

コメントの投稿ボタンを押してエラーが出る原因を特定するためには、より詳細な情報が必要です。エラーのメッセージや、対応するコントローラーとビューのコードを確認する必要があります bitlife。
neenonw89

2024/05/09 09:37

コメントの投稿処理を行うコントローラーのアクションコードを確認してください。コメントフォームを表示するビューのコードも確認してください。入力値の受け取り方や、データベースへの保存処理などが正しく実装されているかを確認します <a href="https://bitlife.online/">bitlife</a>。
guest

回答1

0

エラー分に書いてある通りidを渡してあげる必要があります。
今のコードで実装するには一度変数で受け取る必要があります。

def create comment = Comment.create(comment_params) redirect_to item_path(comment.item) end

また、直接create(comment_params)でパラメータを受け取るよりも
一度空のインスタンスを作成しパラメーターを受け取りそれをsaveメソッドで保存してあげる方が良いかと思います。
association(関連付け)ができているのであればmerge(user_id: current_user.id)ではなく
current_user.commentsのように書くこともできます。
コメントの作成に成功、失敗するケースも考えif文で条件分岐もする必要があるかと思います。
以上のことを踏まえると下記のコードに修正できます。

class CommentsController < ApplicationController def create comment = current_user.comments.build(comment_params) if comment.save flash[:success] = 'コメントの作成に成功しました' redirect_to item_path(comment.item) # コメントと結びつく商品の詳細画面に遷移する else flash[:danger] = 'コメントの作成に失敗しました' redirect_to item_path(comment.item) end end

associationのイメージがつきづらい場合にはコンソールを開いて実行してみると良いかと思います。

user = User.first user.comments.build => <Comment id: nil, body: nil, user_id: 1, item_id: nil, created_at: nil, updated_at: nil>

投稿2021/02/08 05:13

編集2021/02/08 05:24
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

sugiboo_ayumu

2021/02/08 14:26

回答ありがとうございます。 解決しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問