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

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

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

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

Ruby on Rails

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Ajax

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

Q&A

2回答

694閲覧

非同期通信でいいね機能を実装

gen515

総合スコア5

Ruby

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

Ruby on Rails

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

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Ajax

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

0グッド

0クリップ

投稿2021/05/10 02:07

前提・実現したいこと

ruby on railsで写真を投稿してクイズを出すサービスを実装しているのですが、そこで回答一覧ページの中から正解の回答にいいねを非同期通信(ajax)で実装したいのですがうまくいきません。

いいね機能自体は問題なくできるのですが、いいねボタンを押しても表示が切り替わらずページをリロードすると表示が切り替わります。

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

ActionView::Template::Error (undefined local variable or method `answer' for #<#<Class:0x00007f390c140fe0>:0x00007f390c04f870>): 1: $(".answer_<%= answer.id %>").html("<%= escape_javascript(render 'likes/like_button', answer: answer ) %>") app/views/likes/create.js.erb:1:in `_app_views_likes_create_js_erb___364640317277991853_69941495908440'

該当のソースコード

rails

1routes.rb 2 3Rails.application.routes.draw do 4 5 # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html 6 root to: 'toppages#index' 7 8 get 'login', to: 'sessions#new' 9 post 'login', to: 'sessions#create' 10 delete 'logout', to: 'sessions#destroy' 11 12 get 'signup', to: 'users#new' 13 resources :photos do 14 resources :answers, only: [:create, :new] 15 end 16 17 resources :users, only: [:index, :show, :create] do 18 member do 19 get :best_answers 20 end 21 end 22 resources :likes, only: [:create, :destroy] 23 24end 25

rails

1likes_controller.rb 2 3class LikesController < ApplicationController 4 def create 5 answer = Answer.find(params[:answer_id]) 6 current_user.like(answer) 7 flash[:success] = 'いいね' 8 end 9 10 def destroy 11 answer = Answer.find(params[:answer_id]) 12 current_user.unlike(answer) 13 flash[:success] = 'いいね解除' 14 end 15 16end 17 18

クイズに対する回答一覧ページ

rails

1photos/show.html.erb 2 3<p id="notice"><%= notice %></p> 4<div class="row"> 5 <div class="offset-md-3 col-md-5"> 6 <p> 7 <%= image_tag @photo.image.url if @photo.image? %> 8 </p> 9 <p> 10 <strong>クイズの問題:</strong> 11 <%= @photo.content %> 12 </p> 13 14 <%= link_to "回答する", new_photo_answer_path(@photo) %> 15 16 <ul class="list-unstyled"> 17 18 <% @answers.each do |answer| %> 19 20 <div class="media-body"> 21 <div style="border: solid 1px #000; margin-bottom: 8px;"> 22 <div class="user-name"> 23 ユーザ名:<%= answer.user.name %> <div id="answer_<%= answer.id %>" style="float: right;"><%= render 'likes/like_button', answer: answer %></div> 24 </div> 25 <div> 26 <%= answer.content %> 27 </div> 28 </div> 29 </div> 30 </li> 31 <% end %> 32 </ul> 33 <%= paginate @answers %> 34 </div> 35</div> 36 37<%= link_to '戻る', photos_path %> | 38<%= link_to '編集', edit_photo_path(@photo) %> 39

likeボタンの部分テンプレート

rails

1likes/_like_button.html.erb 2 3<% if current_user.best_answers?(answer) %> 4 <%= form_with(model: current_user.likes.find_by(answer_id: answer.id), remote: true, method: :delete) do |f| %> 5 <%= hidden_field_tag :answer_id, answer.id %> 6 <%= f.submit 'いいね解除', class: 'btn btn-primary d-inline' %> 7 <% end %> 8<% else %> 9 <%= form_with(model: current_user.likes.build, remote: true) do |f| %> 10 <%= hidden_field_tag :answer_id, answer.id %> 11 <%= f.submit 'いいね', class: 'btn btn-primary d-inline' %> 12 <% end %> 13<% end %>

rails

1create.js.erb 2 3 4$(".answer_<%= answer.id %>").html("<%= escape_javascript(render 'likes/like_button', answer: answer ) %>")

rails

1destroy.js.erb 2 3$(".answer_<%= answer.id %>").html("<%= escape_javascript(render 'likes/like_button', answer: answer ) %>")

試したこと

エラーメッセージを見ておそらくrenderの時にうまく値が渡ってないのが原因と思い見直してみたのですがうまくいきません。

補足情報(FW/ツールのバージョンなど)

ruby 2.5.3
rails 5.2.5

足りないコードがあれば載せます。ご教授お願いします。

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

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

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

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

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

guest

回答2

0

asmさんと意見が同じで、インスタンス変数にしてあげれば動くと思います
全て理解はしていないので想像ですが、

def create @answer = Answer.find(params[:answer_id]) current_user.like(answer) flash[:success] = 'いいね' end def destroy @answer = Answer.find(params[:answer_id]) current_user.unlike(answer) flash[:success] = 'いいね解除' end $(".answer_<%= @answer.id %>").html("<%= j(render 'likes/like_button', answer: @answer ) %>")

で動くのかなあと思います

投稿2021/05/11 07:06

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

controllerからviewへの変数転送はインスタンス変数に限られます。

ローカル変数の転送はrenderを明示する事で可能ではあります

ruby

1 def create 2 answer = Answer.find(params[:answer_id]) 3 current_user.like(answer) 4 flash[:success] = 'いいね' 5 render locals: {answer: answer} 6 end

面倒だしインスタンス変数でいいと思いますが


資料見つけられなかったのでうろ覚えですが
render answer: answer
だったかもしれません。
(renderrender partial:で扱いが違うんだったかな)

投稿2021/05/10 08:07

編集2021/05/10 14:14
asm

総合スコア15147

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

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

gen515

2021/05/10 11:20

修正したのですが表示は相変わらず変化しませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問