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

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

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

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

1回答

3278閲覧

非同期通信による部分テンプレートの置き換えが上手くいかない。

Masaya_Murakami

総合スコア25

Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2016/10/26 01:49

現在、railsとajaxを使っていいね機能を作ろうとしています。現在、問題は二つあるのですが、まず一つ目の問題を解決したいです。いいね機能はサイトのトップページであるindex.html.erbで実装します。トップページには投稿が複数あり、そのそれぞれがいいねができて、灰色のハートを押すと赤いハートに変わる、赤いハートを押すと灰色に変わるといった動きをさせたいです。その際には合計のいいねの数もカウントしてくれます。なので、投稿のいいね機能にはそれぞれには異なったidをもたせています。今回は仮にid0のいいねを押した時のajaxの部分テンプレートの部分テンプレートの置き換えが上手くいかないことです。現在の動きとしてはid0のいいねを押すと画像と合計いいね数は変わるのですが完全に画面が読み込まれず、もう一回押すとTemplate is missingとなります。コードは下記に載せておくので教えていただければ幸いです。

#posts/index.html.erb <% @posts.each_with_index do |post, i| %> <div class="grid-10"> <div class="thumbnail"> <p><%= post.user.nickname %>さん</p> <p>曲名:<%= post.song_title %><br>アーティスト名:<%= post.singer %></p> <div iframe-content> <iframe class="embed-responsive-item" src="<%= post.youtube_url %>"></iframe> </div> <p><%= post.text %></p> <%= render partial: "likes/like", locals: { post: post, i: i} %> <% if user_signed_in? && post.user_id == current_user.id %> <%= link_to '編集', "/posts/#{post.id}/edit" %> <%= link_to '削除', "/posts/#{post.id}", method: :delete %> <% end %> <%= link_to '詳細', "/posts/#{post.id}" %> </div> </div> <% end %>
#likes/_like.html.erb <% if user_signed_in? %> <% if post.like_user(current_user.id) %> <%= button_to "/posts/#{post.id}/unlike",params:{index: i}, method: :delete, id: i, remote: true do %> <%= image_tag("icon_red_heart.svg") %> <span> <%= post.likes_count %> </span> <% end %> <% else %> <%= button_to "/posts/#{post.id}/like",params:{index: i} ,id: i, remote: true do %> <%= image_tag("icon_heart.svg") %> <span> <%= post.likes_count %> </span> <% end %> <% end %> <% else %> <%= image_tag("icon_heart.svg") %> <span> <%= post.likes_count %> </span> <% end %>
#likes/create.js.erb $('#0').html("<%= j(render partial: 'like', locals: { post: @post,i: @index,like:@likes }) %>");
#likes/destroy.js.erb $('#0').html("<%= j(render partial: 'like', locals: { post: @post,i: @index,like:@likes }) %>");

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

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

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

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

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

guest

回答1

0

controllerのコードと何がTemplate is missingなのかが書かれていないので想像ですが、

buttonに指定されているアクションunlikelikeなのに用意されているテンプレートcreatedestroyだからlikes/_unlike.js.erbやlikes/_like.js.erbがTemplate is missingなんだと思います。

投稿2016/10/26 03:43

hana-da

総合スコア1728

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

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

Masaya_Murakami

2016/10/26 12:59

remote trueの非同期通信でcreateアクション、destroyアクションのそれぞれを行った後にそれと同じ名前のjsファイルがあったら読み込むという流れだと思うのでしょうか違うでしょうか? Template is missingはcreate,destroyそれぞれについてです。
hana-da

2016/10/27 23:15

button_to "/posts/#{post.id}/unlike" button_to "/posts/#{post.id}/like" はどこに行くのでしょう? controller と action を教えてください。
Masaya_Murakami

2016/10/29 00:32

likeはlikesコントローラーのcreateアクションです。 unlikeはlikesコントローラーのdestroyアクションです。 問題はjsファイルの中で持ってきた@indexをどう$('')内で指定するのかだと思うのですがどうでしょうか?
hana-da

2016/11/01 07:18

@indexじゃないでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問