🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails

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

jQuery

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

Q&A

解決済

1回答

1027閲覧

Rails ajax通信でページが更新されない・・・

orori

総合スコア42

Ruby on Rails

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

jQuery

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

0グッド

0クリップ

投稿2019/11/29 12:15

編集2019/11/29 12:16

Rails6でECサイトを作っています。
商品(チケット)一覧ページから商品を選択、ボタンをおしてページ遷移、選択した商品の一覧を表示させようと考えています。

最初に、商品一覧ページで選択した商品はJavaScriptでticketIdsに配列として入ってゆきます。
そして、ボタンを押すと、以下のjQuery文が発動し、下のコントローラにgetリクエストを出します。

js

1$.ajax({ 2 type: "GET", 3 url: "/manage_tickets/", 4 data: { id: ticketIds }, 5 dataType: "html" 6 } 7});

rb

1class ManageTicketsController < ManageController 2 before_action :logged_in_user, only: %i[index create destroy] 3 before_action :correct_user, only: :destroy 4 5 def index 6 @tickets = Ticket.where(id: params[:id]).limit(10) #テストな感じです 7 end

ログを見ると、レンダリングまで問題なく行われているという情報が出ています。

D, [2019-11-29T21:02:57.198735 #83105] DEBUG -- : ↳ app/views/manage_tickets/index.html.erb:22 I, [2019-11-29T21:02:57.199729 #83105] INFO -- : Rendered manage_tickets/index.html.erb within layouts/manage (Duration: 257.7ms | Allocations: 17416) I, [2019-11-29T21:02:57.215902 #83105] INFO -- : Rendered layouts/_header.html.erb (Duration: 3.5ms | Allocations: 1051) I, [2019-11-29T21:02:57.216350 #83105] INFO -- : Rendered layouts/_sidebar.html.erb (Duration: 0.2ms | Allocations: 132) I, [2019-11-29T21:02:57.217211 #83105] INFO -- : Rendered layouts/_footer.html.erb (Duration: 0.7ms | Allocations: 462) I, [2019-11-29T21:02:57.217458 #83105] INFO -- : Completed 200 OK in 281ms (Views: 217.5ms | ActiveRecord: 60.6ms | Allocations: 24203)

しかしそれにも関わらず、ページは遷移せずもとの商品選択画面のままなのです。

なぜなのでしょうか。。

###やってみたこと

・最初jQueryの記述の部分で、dataType: "html"とありますが、最初datatypeとなっていましたので、これを修正しましたが、変わりません。
・エラーは出ていないのですが、トークンが入っていないためなのかと、以下をコピペで上のajax文の前につけてみましたが、変わりません。

js

1 $.ajaxPrefilter(function (options, originalOptions, jqXHR) { 2 var token; 3 if (!options.crossDomain) { 4 token = $('meta[name="csrf-token"]').attr('content'); 5 if (token) { 6 return jqXHR.setRequestHeader('X-CSRF-Token', token); 7 } 8 } 9 });

turbolinksをページapplication.jsから削除してみましたが、変わらず・・・

何卒、よろしくお願いいたします

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

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

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

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

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

2KOH

2019/11/29 14:34

状況がつかめていませんが、もしかして $.ajax でページ遷移させようとしていますか? $.ajax にページ遷移機能はありませんよ。
orori

2019/11/29 14:38

おっしゃるとおり、ajaxでコントローラにリクエストをだしてページ遷移させようと考えていました。レンダリングまでしているのでもう少しでできるのかと思っていましたが、できないのですね。
guest

回答1

0

ベストアンサー

Ajaxはページ遷移をせずにサーバーサイドの処理を行うものです。
dataTypeはあくまでサーバーサイドから返ってくるデータの型を指定するものです。

jQuery.ajax(options)

サーバから返されるデータの型を指定します。省略した場合は、jQueryがMIMEタイプなどを見ながら自動的に判別します。指定可能な値は、次のようなものです。

通常は、サーバーサイドから返ってきた情報をJavaScriptでHTMLを書き換えていきます。
はじめてのAjax(jQuery) 2018年版
にあるように、通信・処理成功した場合、done()で結果を受け取るので、
そこで返ってきた結果を確認し、適宜HTMLに反映すると良いでしょう。

投稿2019/11/29 21:39

m.ts10806

総合スコア80875

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

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

orori

2019/12/01 15:07

>通常は、サーバーサイドから返ってきた情報をJavaScriptでHTMLを書き換えていきます。 Railsには上の機能が備わっているということなのですね、 またdone()コールバックで帰ってきた結果をHTMLにすれば通常の動作と同じことになるわけですね。 Rails内部の動きももっと学ばねばならないですね。 ありがとうございました!
m.ts10806

2019/12/01 21:22

Railsはあくまでサーバーサイドのフレームワークです。(VIEWも結局は画面に表示させるために裏ではサーバーサイドの置換処理が走っているはず) Ajaxとの連携についてはドキュメントや紹介記事などであると思うので、探してください。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問