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

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

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

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

Ruby on Rails

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

JavaScript

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

Ajax

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

Q&A

解決済

1回答

696閲覧

Rails非同期「いいね」機能 create時のみレンダリングしない

kkbeams

総合スコア17

Ruby

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

Ruby on Rails

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

JavaScript

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

Ajax

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

0グッド

0クリップ

投稿2020/08/30 05:32

rails でコンテンツを投稿し、各コンテンツの詳細画面に非同期で「いいね機能」を作っています。

------------起きている問題------------

コンテンツ詳細画面を開く 

ボタン状態:未いいね

↓ いいね押す(createされるがレンダリングしない) ※ここが問題点

ボタン状態:未いいね

↓ リロードしてみる

ボタン状態:いいね済

↓いいね押す(destroyされ、レンダリングされる)

ボタン状態:未いいね

---------繰り返し---------

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

ActionView::Template::Error (No route matches {:action=>"destroy", :content_id=>5, :controller=>"user/favorites"}, missing required keys: [:id]): 1: <% if content.liked_by?(current_user) %> 2: <%= button_to content_favorite_path(content.id), method: :delete, remote: true, class:"buy-btn fav-delete-btn" do %> 3: <span>いいね解除</span> 4: <% end %> 5: <% else %> app/views/user/favorites/_favorite.html.erb:2 app/views/user/favorites/create.js.erb:1

routes.rb

Ruby

1authenticated :user do 2 scope module: :user do 3 resources :contents, only: [:index, :new, :create, :show, :destroy] do 4 resources :favorites, only: [:create, :destroy] 5 end 6 end 7end

model

content.rb

Ruby

1class Content < ApplicationRecord 2 belongs_to :user 3 has_many :favorites, dependent: :destroy 4 5 validates :user_id, presence: true 6 7 def liked_by?(user) 8 favorites.where(user_id: user.id).exists? 9 end 10end

user.rb

Ruby

1class User < ApplicationRecord 2 has_many :contents, dependent: :destroy 3 has_many :favorites, dependent: :destroy 4end

favorite.rb

Ruby

1class Favorite < ApplicationRecord 2 belongs_to :user 3 belongs_to :content 4 validates :user_id, uniqueness: { scope: :content_id } 5end

###favorites_controller.rb

Ruby

1(app/controllers/user/favorites_controller.rb) 2 3class User::FavoritesController < ApplicationController 4 before_action :set_variables 5 6 def create 7 @favorite = current_user.favorites.create(content: @content) 8 end 9 10 def destroy 11 favorite = Favorite.find_by(content: @content, user_id: current_user.id) 12 favorite.destroy 13 end 14 15 private 16 17 def set_variables 18 @content = Content.find(params[:content_id]) 19 @id_name = "#favorites_buttons_#{@content.id}" 20 end 21end

###show.html.erb

(app/views/user/contents/show.html.erb) <div id="favorites_buttons_<%= @content.id %>"> <%= render partial: 'user/favorites/favorite', locals: { content: @content} %> </div>

###_favorite.html.erb

(app/views/user/favorites/_favorite.html.erb) <% if content.liked_by?(current_user) %> <%= button_to content_favorite_path(content.id), method: :delete, remote: true, class:"buy-btn fav-delete-btn" do %> <span>いいね解除</span> <% end %> <% else %> <%= button_to content_favorites_path(content.id), method: :post, remote: true, class:"buy-btn fav-btn" do %> <span>いいね!</span> <% end %> <% end %>

###create.js.erb destroy.js.erb

(app/views/user/favorites/create.js.erb) (app/views/user/favorites/destroy.js.erb) $('<%= @id_name %>').html("<%= j(render partial: 'user/favorites/favorite', locals: {content: @content}) %>");

試したこと

ルーティングがネスト構造になっているため、viewファイルの位置がおかしいのかと思い、フォルダー作ったり、ファイルを移動させたりしたのですが、解決できませんでした。。。

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

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

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

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

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

no1knows

2020/08/30 08:43

問題点のところで、発生している問題・エラーメッセージが表示されるという認識で良いのでしょうか?
guest

回答1

0

ベストアンサー

以下のエラー文を見ると missing required keys: [:id]とかかれているのことから、必要なIDがないために、レンダリングに失敗していそうです。

ActionView::Template::Error (No route matches {:action=>"destroy", :content_id=>5, :controller=>"user/favorites"}, missing required keys: [:id]):

いいね解除ボタンで、content_favorite_path(content.id)とかかれていますが、deleteのPathで引数が2つ必要なところを1つしか渡していないのかと思いました。以下のようにするといかがでしょうか(引数の値はとりあえず適当です)。

content_favorite_path(content.id, content.id)
  • 1つめの引数が、およそDeleteしたいFavoriteテーブルのID
  • 2つめの引数が、content_id

になる気がします。

投稿2020/08/30 07:42

hatsu

総合スコア1809

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問