前提・実現したいこと
現在railsで記事アプリの中でいいね機能を実装していて、画面遷移すればいいねのカウントがされ、色が変わるようになっています。そこでjQueryで非同期処理をして、画面遷移せずともその動作が反映させられるようにしたいです。
なお、gem'jquery-rails'はinstall済みで、application.jsにもrequireを記載しています。
該当のソースコード
routes.rb (いいねのルーティングはlikesでarticlesにネストさせています)
rb
1Rails.application.routes.draw do 2 devise_for :users 3 # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html 4 root "articles#index" 5 resources :articles do 6 resources :likes, only: [:create, :destroy] 7 end 8 resources :users 9end
articles/_like.html.erb (fontawesomeのアイコンをlink_toに埋め込んでいます。like_countはいいね された回数です。)
rb
1<% if user_signed_in? %> 2 <% if article.user_liked(current_user.id) %> 3 <%= link_to article_like_path(article, article_id: article.id), method: :delete, class: "destroy", remote: true do %> 4 <i class="fas fa-heart"> 5 <span> 6 <%= article.like_count %> 7 </span> 8 </i> 9 <% end %> 10 <% else %> 11 <%= link_to article_likes_path(article), method: :post, class: "create",remote: true do %> 12 <span> 13 <i class="far fa-heart"> 14 <%= article.like_count %> 15 </i> 16 </span> 17 <% end %> 18 <% end %> 19<% else %> 20 <%= link_to user_session_path do %> 21 <i class="far fa-heart"> 22 <span> 23 <%= article.like_count %> 24 </span> 25 </i> 26 <% end %> 27<% end %>
この部分テンプレートをtopページであるarticles/index.html.erbに使っています。
erb
1<% @articles.each do |article| %> 2 <%= render partial: "articles/list", locals: { article: article } %> 3 <%= render partial: "articles/like", locals: { article: article } %> 4<% end %> 5
likes_controller.rb
rb
1class LikesController < ApplicationController 2 def create 3 @like = Like.create(user_id: current_user.id, article_id: params[:article_id]) 4 redirect_to root_path 5 end 6 7 def destroy 8 like = Like.find_by(user_id: current_user.id, article_id: params[:id]) 9 like.destroy 10 @likes = Like.where(article_id: params[:id]) 11 @articles = Article.all 12 redirect_to root_path 13 end 14end
試したこと
likes配下にcreate.js.erbとdestroy.js.erbを作って、link_toに与えたclassで
$(#create).html(j<%= render partial "like" %>)などやってみましたがだめでした。
補足情報(FW/ツールのバージョンなど)
MacOS Cloud9 ruby2.5.1 rails5
長くて読みづらいのですが回答よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー