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

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

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

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

jQuery

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

Ajax

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

Q&A

0回答

1373閲覧

Rails Ajaxの部分テンプレート更新がうまくできない

ruby_0ct

総合スコア57

Ruby on Rails

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

jQuery

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

Ajax

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

0グッド

0クリップ

投稿2018/02/10 06:52

絞り込み検索をした結果をAjaxを使って表示させたいのですが、書き換えがうまくいかず、困っています。

音楽のカテゴリー絞り検索です。

DBから取得した検索結果をcontroller内である編集するために、
Active Recordオブジェクトから、配列の中にハッシュを格納させる形で変換しました。

viewに渡す検索結果

[{:id=>1, :songtitle=>"LIFE", :artist =>"キマグレン", :category =>"jpop"}, {:id=>2, :songtitle=>"Because Of You", :artist =>"Ne-Yo", :category=>"R&B"}]

musics_controller.rb

def datasort search_data = Music.includes(:categorynumber).order(created_at: params[:newoldsort]) recodedata = search_data.pluck(:id, :songtitle, :artist, :category) keys = ['id', 'songtitle', 'artist', 'category'] @songdata = search_data.map { |search_data| Hash[*[:id, search_data.id], *[:songtitle, search_data.songtitle], *[:artist, search_data.artist], *[:category, search_data.category]]} # 先ほど言ったある編集とは、新たにhashのキーを追加する処理です。 @songdata.each do |keys| # 各データにキーを新規追加したいので展開します。 if keys[:artist] == 'キマグレン' keys[:catchphrase] = "今、日本で人気のアーティスト" # キャッチフレーズというキーを新規追加 else keys[:catchphrase] = "良いアーティスト" # キマグレン以外のキャッチフレーズ end end end

ちなみに、DBのテーブルは、曲自体のテーブルとカテゴリーテーブルの2つあり、1対多の関係です。
曲テーブルからは1つしか参照できませんが、カテゴリーテーブルからはいくつでも参照できます。

この後はviewに渡し部分テンプレートでAjaxを使ってeach展開させて表示させます。

/view/musics/datasort.js.erb

$('#musicdata').html('<%= j(render partial: 'songs') %>');

/view/musics/_songs.html.erb

<div id="musicdata"> <% @songdata.each do |song| %> <%= link_to song_path(song[:id]) do %> <%#= 曲の詳細ページへのリンク生成 %> <p>キャッチフレーズ:<%= song[:catchphrase] %></p> <p>曲名:<%= song[:songtitle] %></p> <p>アーティスト:<%= song[:artist] %></p> <% end %> <% end %> </div>

ルーティング

get 'musics/datasort' post 'musics/datasort'

絞り込み検索をした際のコンソール

Rendering musics/datasort.js.erb Rendered musics/_songs.html.erb (3.3ms) Rendered musics/datasort.js.erb (28.0ms) Completed 200 OK in 116ms (Views: 73.9ms | ActiveRecord: 4.5ms)

Chromeのパケットをみるとちゃんとpostは受信されているのですが、書き換えだけがうまくいきません。
どうしたら正常に行われるでしょうか?

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問