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

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

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

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

Q&A

解決済

1回答

1310閲覧

rails の いいねをajax化したい

roy20

総合スコア19

Ruby on Rails 5

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

0グッド

0クリップ

投稿2019/07/08 13:48

railsでいいね機能をajax化したいです

ページを更新すればいいねができるのですが、非同期通信ができません。qiitaのいいねajax系の記事はほとんど読んで見て解決しようとトライしたのですが、未だ解決方法がわかりません。

まずajaxではない いいねを追加した後にajax化しようとしていました。色々な記事を参照したので、コードが汚くなっていると思います。

モデル

like.rb

class Like < ApplicationRecord belongs_to :post belongs_to :user validates_uniqueness_of :post_id, scope: :user_id end

user.rb

class User < ApplicationRecord has_many :posts, dependent: :destroy has_many :likes, dependent: :destroy has_many :liked_posts, through: :likes, source: :post def already_liked?(post) self.likes.exists?(post_id: post.id) end end

post.rb

class Post < ApplicationRecord belongs_to :user has_many :likes, dependent: :destroy has_many :liked_users, through: :likes, source: :user end

###ルーティング

routes.rb

Rails.application.routes.draw do get '/login', to: 'sessions#new' post '/login', to: 'sessions#create' delete '/logout', to: 'sessions#destroy' namespace :admin do resources :users end root to: 'posts#top' resources :posts do resources :likes, only: [:create, :destroy] end end

###コントローラー

likes_contoroller

class LikesController < ApplicationController def create @post = Post.find(params[:post_id]) like = current_user.likes.build(post_id: params[:post_id]) like.save end def destroy @post = Post.find(params[:post_id]) like = Like.find_by(post_id: params[:post_id], user_id: current_user.id) like.destroy end end

###テンプレート

_like.html.slim

- if current_user.already_liked?(@post) span お気に入り解除: = link_to post.likes.count, post_like_path(@post), method: :delete, remote: true - else span お気に入り登録: = link_to post.likes.count, post_likes_path(@post), method: :post, remote: true

###js

create.js.erb

$('#likes_buttons_<%= @post.id %>').html("<%= j(render partial: 'likes/like', locals: {post: @post}) %>");

destroy.js.erb

$('#likes_buttons_<%= @post.id %>').html("<%= j(render partial: 'likes/like', locals: {post: @post}) %>");

###現状
ページを更新すればいいねがカウントされて数字が増えますが、期待しているajaxの動きにはなりません。_like.html.slimが何かおかしいのかもしれないと思っていますが、どのようにすればいいか検討がつきません。よろしくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

- if current_user.already_liked?(@post) span お気に入り解除: = link_to post.likes.count, post_like_path(post, post_id: post.id), method: :delete, id: "like-button", remote: true - else span お気に入り登録: = link_to post.likes.count, post_likes_path(post), id: "like-button", method: :post, remote: true

ログを見て、key?を指定したらできました。正直ググってそれを見ただけなので解決方法がなぜこのような結果になるかわからないです。

ActionView::Template::Error (No route matches {:action=>"destroy", :controller=>"likes", :post_id=>#<Post id: 3, name: "やば", description: "やばいね", created_at: "2019-06-26 13:12:31", updated_at: "2019-06-26 13:12:31", user_id: 1>}, missing required keys: [:id]):

投稿2019/07/08 14:20

roy20

総合スコア19

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問