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

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

詳細はこちら
Ruby on Rails 6

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

JavaScript

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

Q&A

解決済

2回答

957閲覧

JavaScriptの非同期通信でのDB保存

fastman

総合スコア3

Ruby on Rails 6

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

JavaScript

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

0グッド

0クリップ

投稿2021/02/01 08:14

編集2021/02/02 03:16

前提・実現したいこと

非同期通信を使って(Ajax)json形式でストップウォッチの時間をid="rap"を押したときに取得してDBに保存したい。

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

すべてのパラメータがnilで返ってくる

該当のソースコード

new

1<%# タイマーの時間表示 %> 2<div class="stop-watch"> 3 <p id="time">00:00:00.000</p> 4</div> 5 6<%# STARTとSTOPのボタン %> 7<%= form_with url: watches_path, class: "buttons" do |f| %> 8 <%= f.submit "START", class: "btn", id: "start" %> 9 <%= f.submit "RAP", class: "btn", id: "rap" %> 10<% end %>

controller

1def create 2 @watch = Watch.create(watch: params[:watch]) 3 render json:{ watch: @watch } 4end

javascript

1function addRap() { 2 const XHR = new XMLHttpRequest(); 3 const time = document.getElementById("time").innerHTML; 4 XHR.open("POST", "/watches", true); 5 XHR.setRequestHeader('content-type', 'application/json') 6 XHR.onreadystatechange = () => { 7 if (this.readyState === XMLHttpRequest.DONE && this.status === 200) { 8 const content = XHR.response; 9 console.log(content) 10 } 11 }; 12 XHR.send("watch="+time); //400(Bad Error) 13 } 14 15 rap.addEventListener('click', (e) => { 16 addRap(); 17 e.preventDefault(); 18 } 19 });

routes

1Rails.application.routes.draw do 2 devise_for :users 3 4 resources :watches, only: [:index, :new, :create] 5end

addEventListnerでクリックしたときにaddRap()を発火させています。

試したこと

controllerでストロングパラメータを指定した

最後に

過不足あるかと思いますがよろしくおねがいします。

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

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

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

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

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

m.ts10806

2021/02/01 09:51 編集

ルーティングと、 addEventListnerのコードも含めて提示してください。 id=timeの要素がどこにあるかとか。 あとブラウザ開発ツールのコンソールにエラー出てませんか? サーバー側のコンソールに何か出てませんか? 他者が状況把握するために、過はありませんが不足ばかりです。 質問者が過すぎたなと思うくらいがちょうど良いです。
fastman

2021/02/01 10:25 編集

ご指摘ありがとうございます。以降気をつけたいと思います。 情報を追記させていただきましたので、ご教授お願いできますでしょうか? なお、コンソールにはエラーがでず、{id: null, watch: null, ....}のようにすべてnullで返ってきます。また、その後コンソールでかくにんしたところ、変数timeには正しいデータがコンソールに表示できましたので、おそらく、送信した際またはデータを受け取った際に間違っているところがあるようです。
guest

回答2

0

自己解決

空のFormDataを生成して、appendで必要な情報を代入し、ajaxにするとできました。

投稿2021/02/19 06:33

fastman

総合スコア3

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

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

0

const time = document.getElementById("time").innerHTML;

XHR.send(time);

だと、リクエストはちゃんと送られないのでは。
XMLHttpRequest.send()

params[:watch]で受け取られているので、

例えば、こう?

js

1XHR.send("watch="+time);

投稿2021/02/01 10:46

m.ts10806

総合スコア80875

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

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

fastman

2021/02/01 15:15

innerHTMLをAjaxで送ること自体が無理なのでしょうか。。。 ご教授いただいた内容で試してみましたが、うまくいきませんでした。
m.ts10806

2021/02/01 21:36

「うまくいかない」と言われてもこちらには何が起きたのか伝わっていません。 >innerHTMLをAjaxで送ること自体が無理なのでしょうか。。。 無関係です。送るのは結局は変数であり文字列。 リクエスト内容と受け取る側が一致していれば問題ありません。
m.ts10806

2021/02/01 21:41

あと、回答に提示したリンクだとGETはonloadですが、POSTはonreadystatechange でコールバックですね。
fastman

2021/02/02 03:14 編集

>ご教授いただいた内容で試してみましたが、うまくいきませんでした。 →返り値は変わらず{id:null, watch:null,....}でした。 回答で提示いただいた内容を元に書き換えてみましたが、XHR.send("watch="+time)のところで400エラーで、XHR failed loading POSTになり送信できませんでした。 JSの変更点は書き換えました。
m.ts10806

2021/02/02 02:41

質問は編集できますので。
fastman

2021/02/02 07:19

失礼しました。修正しました。 また、コントローラーでbinding.pryでデバッグしたところ、パラメータがすべてnilでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問