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

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

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

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

Ruby

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

JavaScript

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

Q&A

1回答

871閲覧

非同期化したいいね欄がずれてしまいます。

n-s0120

総合スコア1

Ruby on Rails 5

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

Ruby

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

JavaScript

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

0グッド

0クリップ

投稿2021/08/19 04:46

編集2021/08/19 06:50

前提・実現したいこと

いいね機能の非同期化をしたいと思っています。

いいね機能の非同期通信を実装したときに、いいね前といいね後で、テーブルのtdがずれてしまい、困っております。

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

下記スクリーンショットの通りです。

いいね前
イメージ説明

いいね後
イメージ説明

該当のソースコード

ruby

1# frozen_string_literal: true 2 3class ArticlesController < ApplicationController 4 def new 5 @article = Article.new 6 end 7 8 def create 9 @article = Article.new(article_params) 10 @article.user_id = current_user.id 11 if @article.save 12 redirect_to articles_path 13 else 14 render :new 15 end 16 end 17 18 def index 19 @articles_new = Article.all.order(created_at: :desc).page(params[:page]) 20 # tagを押したとき、同じタグが付いているもののみを表示 21 @articles_new = Article.tagged_with(params[:tag_name].to_s).page(params[:page]) if params[:tag_name] 22 end 23 24 def index_favorite 25 @articles_favorite = Kaminari.paginate_array(Article.includes(:favorites).sort { |a, b| b.favorites.count <=> a.favorites.count }).page(params[:page]) 26 @articles_favorite = Kaminari.paginate_array(Article.tagged_with(params[:tag_name].to_s).includes(:favorites).sort { |a, b| b.favorites.count <=> a.favorites.count }).page(params[:page]) if params[:tag_name] 27 end 28 29 def index_comment 30 @articles_comment = Kaminari.paginate_array(Article.includes(:comments).sort { |a, b| b.comments.count <=> a.comments.count }).page(params[:page]) 31 @articles_comment = Kaminari.paginate_array(Article.tagged_with(params[:tag_name].to_s).includes(:comments).sort { |a, b| b.comments.count <=> a.comments.count }).page(params[:page]) if params[:tag_name] 32 end 33 34 def show 35 @article = Article.find(params[:id]) 36 @comment_new = Comment.new 37 end 38 39 def edit 40 @article = Article.find(params[:id]) 41 end 42 43 def update 44 @article = Article.find(params[:id]) 45 @article.update(article_params) 46 redirect_to article_path(@article) 47 end 48 49 def destroy 50 @article = Article.find(params[:id]) 51 @article.destroy 52 redirect_to articles_path 53 end 54 55 private 56 57 def article_params 58 params.require(:article).permit(:title, :introduction, :url, :tag_list) 59 end 60end 61

ruby

1<div class="article_content"> 2 <div class="article-submit"> 3 <% if user_signed_in? %> 4 <%= link_to "記事を投稿する", new_article_path, class: 'btn btn-primary' %> 5 <% end %> 6 </div> 7 8 <div class="article-sort"> 9 <%= link_to "新着順", articles_path, class: 'btn btn-info' %> 10 <%= link_to "いいね順", articles_favorite_sort_path, class: 'btn btn-info' %> 11 <%= link_to "コメント数順", articles_comment_sort_path, class: 'btn btn-info' %> 12 </div> 13 14 <table border="1"> 15 <thead> 16 <tr> 17 <th>ユーザー名</th> 18 <th>記事タイトル</th> 19 <th>記事紹介文</th> 20 <th>タグ</th> 21 <th>コメント数</th> 22 <% if user_signed_in? %> 23 <th>いいね</th> 24 <% end %> 25 <th>いいね数</th> 26 <th>記事の詳細ページ</th> 27 <th>記事作成日時</th> 28 </tr> 29 </thead> 30 <!--each文のリファクタリング--> 31 <%= render partial: 'article', collection: @articles_new, as: :article %> 32 </table> 33 34 <!--kaminariのページング--> 35 <div class="paging"> 36 <%= paginate @articles_new %> 37 </div> 38</div> 39

ruby

1<!--記事のtd要素の部分テンプレート--> 2<tbody> 3 <tr id='article_<%= article.id %>'> 4 <td><%= article.user.name %></td> 5 <td><%= article.title %></td> 6 <td><%= article.introduction %></td> 7 <!--acts-as-taggable-onの部分テンプレート--> 8 <td><%= render 'favorites/tag_list', tag_list: article.tag_list %></td> 9 <td><%= article.comments.count %></td> 10  <!--ユーザーとしてサインしている場合にいいね機能を利用可能--> 11 <% if user_signed_in? %> 12 <td> 13 <% if article.favorited_by?(current_user) %> 14 <%= link_to article_favorites_path(article), method: :delete, remote: true do %>♥<% end %> 15 <% else %> 16 <%= link_to article_favorites_path(article), method: :post, remote: true do %><% end %> 17 <% end %> 18 </td> 19 <% end %> 20 <td><%= article.favorites.count %></td> 21 <td><%= link_to "詳細", article_path(article) %></td> 22 <!--日本時間に変更--> 23 <td><%= article.created_at.strftime('%Y/%m/%d %H:%M') %></td> 24 </tr> 25</tbody>

javascript

1document.getElementById("article_<%= @article.id %>").innerHTML = '<%= j(render @article) %>'

試したこと

コードのとおりです。

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

必要な情報がありましたら、お聞きください。

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

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

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

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

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

guest

回答1

0

js部分の<%= j(render @article) %>で作成されるhtmlが<td>から始まっていないという事はないでしょうか?

もし「記事のtd要素の部分テンプレート」で記載されている部分がまるまる生成されているようならinnerHTMLで書き換えた時

html

1<tbody> 2 <tr id="article_xx"> 3 <tbody> 4 <tr id="article_xx"> 5 <td>.....</td> 6 <td>.....</td> 7 <td>.....</td> 8 </tr> 9 </tbody> 10 </tr> 11</tbody>

のようにネスト状態になってしまいます。

投稿2021/08/20 02:54

webgoto

総合スコア1293

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問