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

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

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

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Ajax

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

Q&A

解決済

2回答

4599閲覧

Ajaxを使ってフォーム内容を保持

maonmyo

総合スコア36

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Ajax

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

0グッド

0クリップ

投稿2016/11/08 08:17

編集2016/11/09 09:41

[やりたいこと]
・Ajaxを使って送信ボタンを押した時にフォームの値が消えないようにしたい。

[ながれ]
index画面で検索に必要なフォーム入力(未入力可)
検索ボタン押下。
同画面に検索結果表示。

index画面ではindexアクションのみ行われます。
アクション内容はフォーム入力値を使った複合検索。

Ajaxを使うことで画面遷移がないため、フォームの値は残る。
ボタンクリックでアクションを走らせ、フォーム内容はPOSTで送信、検索結果を表示。という流れを目指してます。

自己解決しました。
お世話様です。

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

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

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

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

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

guest

回答2

0

自己解決

javascript

1 2$('#search').on('click', function(){ 3 var sendData = $('#form_search').serialize(); 4 $.ajax({ 5 data: sendData, 6 url:'user/search', 7 type:'post' 8 }).done(function (returnData){ 9 console.log('OK'); 10 }); 11 }); 12

ruby

1[html.erb] 2 3<form id="form_search"> 4 <input type="text" id="id" name="id"> 5 <input type="text" id="name" name="name"> 6 <select name="human" id="human"> 7 <option value="0">大人</option> 8 <option value="1">子供</option> 9 </select> 10 <button type="button" id="search">検索</button> 11</form>

上記のコードにしたことで
controller側から、paramsでフォームの値を受け取ることができました。
本来の質問である「フォーム内容の保持」はAjaxを使用する段階で解決しているようなので
このまま解決ということにさせていただきます。

投稿2016/11/09 09:43

maonmyo

総合スコア36

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

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

0

Ajaxを使って送信ボタンを押した時にフォームの値が消えないようにしたい。

「Ajaxを使わないで」ならできますか? 質問に書かれている内容であればAjaxを使わなくてもできそうです。

Ajaxを使わない方が難易度は低めなので

「Ajaxを使って」というのがどういうことなのかイマイチぴんときません。

という状態であれば、まずは「Ajaxを使わないで」やってみましょう。

それで何かの要件が満せないのであればAjaxを使えば満せるのかを考え、Ajaxを使えば満せるようであれば使えばいいと思います。

投稿2016/11/08 09:51

hana-da

総合スコア1728

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

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

maonmyo

2016/11/09 06:06

いつもありがとうございます。 内容を修正しましたので、よろしくおねがいします。
hana-da

2016/11/09 07:13

今夜時間があればみてみます(_ _
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問