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

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

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

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

Ruby on Rails

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

0回答

843閲覧

いいね機能の非同期化ができない(リロードしないと反映されない)

Solt24times

総合スコア32

Ruby

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

Ruby on Rails

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

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2022/02/28 08:20

編集2022/02/28 09:07

前提・実現したいこと

タイトルの通り自作しているアプリにいいね機能を同期か状態で実装してそちらに手を加えて非同期かを測ろうとしたのですがうまくいかない状態です。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

下記のサイトを参考にいいねボタンを押した際、ツイッターのハートマークの様にアイコンが黒から黄色に変わるように実装したいのですがリロードしないと色が変わらない状態です。
いいねのデータ自体はDBに保存されていますので同期化での実装はできているようです。
参考にしたHP:https://techtechmedia.com/favorite-function-rails/

エラーメッセージ
検証で調べた際には以下のエラーが出ました。
https://gyazo.com/07e041125c0e499f5b96f102dfe73cdf

他にもターミナルに以下のエラーが出てきていました。

ActionView::Template::Error (Missing partial scenarios/_scenario with {:locale=>[:ja], :formats=>[:js, :html, :text, :css, :ics, :csv, :vcf, :vtt, :png, :jpeg, :gif, :bmp, :tiff, :svg, :mpeg, :mp3, :ogg, :m4a, :webm, :mp4, :otf, :ttf, :woff, :woff2, :xml, :rss, :atom, :yaml, :multipart_form, :url_encoded_form, :json, :pdf, :zip, :gzip], :variants=>[], :handlers=>[:raw, :erb, :html, :builder, :ruby, :jbuilder]}. Searched in:

該当のソースコード

scenario_controller(アプリのメイン機能のコントローラー一部抜粋)

(省略) def show @scenario = Scenario.find(params[:id]) @comment = Comment.new @comments = @scenario.comments.includes(:user) @tags = @scenario.tag_counts_on(:tags) end (省略)

like_controller(いいね機能のコントローラー)

class LikesController < ApplicationController before_action :like_params def create @like = Like.create(user_id: current_user.id, scenario_id: params[:id]) end def destroy Like.find_by(user_id: current_user.id, scenario_id: params[:id]).destroy end private def like_params @scenario = Scenario.find(params[:id]) end end

show.html.erb(いいねアイコン表示の部分のみ記載)

<%= render "shared/header" %> <div id="scenario_<%= @scenario.id %>" > <%= render partial: 'shared/like', locals: {scenario: @scenario, likes: @likes} %> </div> <div class="main">(以下略)

_like.html.erb(上記ビューの部分テンプレート部分)

<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.9.0/css/all.css"> <% if current_user.liked_by?(@scenario.id) %> <%= link_to destroy_like_path(@scenario), class: "like_button", method: :DELETE, remote: true do %> <i class="fas fa-crown fa-3x like_off" ></i> <% end%> <% else %> <%= link_to create_like_path(@scenario), class: "like_button", method: :POST, remote: true do %> <i class="fas fa-crown fa-3x like_on" ></i> <% end %> <% end %>

create.js.erbおよびdestroy.js.erb(いいね、いいね解除のjs)

document.getElementById('scenario_<%= @scenario.id %>').innerHTML = '<%= j(render @scenario) %>'

試したこと

idが付いていないことで反映されないとの情報があったので< id="scenario_<%= @scenario.id %>" としたのですが解決できずでした。
またspanやdivで囲う必要があるともあったので上記内容をdivで囲ったのですが同様に解決に至らずでした。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問