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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

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

Q&A

解決済

1回答

1688閲覧

link_toで編集画面にリンクさせたいが、リンク先が正しく表示されない。

ytommy

総合スコア11

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

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

0グッド

0クリップ

投稿2020/04/18 02:04

前提・実現したいこと

編集画面へのリンクを作成したのですが、リンク先が表示されない。

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

ActiveRecord::RecordNotFound in ReviewsController#edit Couldn't find Review with 'id'=6

該当のソースコード

#routes.rb Rails.application.routes.draw do devise_for :users resources :wines do resources :reviews, except: [:show, :index] end # ログアウト devise_scope :user do get 'sign_out', to: "sessions#destroy" end resources :users, controllers: { registrations: 'users/registrations' } root 'wines#index' end
#show.html.erb . .(略) . <%= link_to "編集する", edit_wine_review_path(review.id), class: "btn btn-light" %> . .(略) .
#reviews_controller.rb class ReviewsController < ApplicationController before_action :set_review, only: [:show, :edit, :update, :destroy] before_action :authenticate_user! before_action :set_wine def new @review = Review.new end def edit end def create @review = Review.new(review_params) @review.user_id = current_user.id @review.wine_id = @wine.id respond_to do |format| if @review.save format.html { redirect_to @wine, notice: 'Review was successfully created.' } format.json { render :show, status: :created, location: @review } else format.html { render :new } format.json { render json: @review.errors, status: :unprocessable_entity } end end end def update respond_to do |format| @review.user_id = current_user.id @review.wine_id = @wine.id if @review.update(review_params) format.html { redirect_to @review, notice: 'Review was successfully updated.' } format.json { render :show, status: :ok, location: @review } else format.html { render :edit } format.json { render json: @review.errors, status: :unprocessable_entity } end end end def destroy @review.destroy respond_to do |format| format.html { redirect_to reviews_url, notice: 'Review was successfully destroyed.' } format.json { head :no_content } end end private def set_review @review = Review.find(params[:id]) end def set_wine @wine = Wine.find(params[:wine_id]) end def review_params params.require(:review).permit(:rating, :comment, :price) end end

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

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

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

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

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

hatsu

2020/04/18 02:41

rails routes | grep review の結果を見てみたいです。 パスに必要な変数が用意されていないと考えているため。
ytommy

2020/04/18 02:49

windowsなのでrails routes | findstr reviewしてみました。 下記です。 wine_reviews POST /wines/:wine_id/reviews(.:format) reviews#create new_wine_review GET /wines/:wine_id/reviews/new(.:format) reviews#new edit_wine_review GET /wines/:wine_id/reviews/:id/edit(.:format) reviews#edit wine_review PATCH /wines/:wine_id/reviews/:id(.:format) reviews#update PUT /wines/:wine_id/reviews/:id(.:format) reviews#update DELETE /wines/:wine_id/reviews/:id(.:format) reviews#destro
guest

回答1

0

ベストアンサー

routesを見るとWineのレビューを編集する画面へのパスは以下です。

routes

1edit_wine_review GET /wines/:wine_id/reviews/:id/edit(.:format) reviews#edit

必要な変数は、wine_ididのようです。なので

edit_wine_review_path(wind, review)

としてあげると、Couldn't find Review with 'id'=6のように「口コミが見つからない」といったエラーはなくなるかと思います。

投稿2020/04/18 02:57

hatsu

総合スコア1809

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

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

ytommy

2020/04/18 03:04

edit_wine_review_path(@wine, review)としたところ、 正常に表示されました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問