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

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

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

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Q&A

解決済

1回答

1626閲覧

railsでjQueryを使って画面遷移せずにいいねが保存・削除されるようにしたい

chocolate24

総合スコア125

Ruby on Rails 5

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

0グッド

0クリップ

投稿2020/05/28 02:28

前提・実現したいこと

現在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

長くて読みづらいのですが回答よろしくお願いいたします。

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

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

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

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

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

HTMLdoc

2020/05/28 02:49

エラー内容がないと何とも言えません
guest

回答1

0

自己解決

知り合いに相談したところ、解決しました。具体的にいうと
likes_controllerで@articleを定義して

def create @like = Like.create(user_id: current_user.id, article_id: params[:article_id]) @article = Article.find(params[:article_id]) end

ビューでidを付与したクラスの中に入れ、(ここで@articleを渡す)

<div id="like-<%= @article.id %>"> <%= render partial: "articles/like", locals: { article: @article } %> </div>

create.js.erbでもう一回_like.html.erbを読み込みます

$("#like-<%= @article.id %>").html("<%= j(render partial: 'articles/like', locals: {article: @article}) %>")

投稿2020/05/28 06:38

chocolate24

総合スコア125

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問