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

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

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

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

jQuery

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

Q&A

解決済

1回答

397閲覧

スマホ 必須入力inputタグに対するhideメソッドの挙動 未変換の状態(未確定文字)からhideで非表示にすると、入力内容が消えてしまう

kotahayashi

総合スコア15

Ruby on Rails

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

jQuery

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

0グッド

0クリップ

投稿2018/06/11 05:20

前提・実現したいこと

JQueryと ruby on rails を使って、チャット型の入力フォームを作成しています。

下記のように、特に平仮名や句点(。)等、未変換の状態(未確定文字)でhideメソッドを実行しても、
入力内容を保持したいと考えています。

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

画像のように、一部の文字の背景が青色(未変換の状態)で「非表示」を押下してhideメソッドで非表示とすると、
入力内容が消えてしまっているせいか'required: true'のバリデーションが働き、フォーム送信ボタンで送信できない。

該当のソースコード

HTML

1<%= form_for([@hoge, @fuga]) do |f| %> 2 <div class="input"> 3 <%= f.text_field :hoge, {id: 'text-hoge', type: 'text', required: true} %> 4 </div> 5 <input type="button" value="非表示" onclick="hide_click()"/> 6<% end %>

Javascript

1function hide_click() { 2 $('.input').hide(); 3} 4

試したこと

https://teratail.com/questions/129963
こちらの質問でのご回答を参考に、試行錯誤しましたが、うまくいきませんでした。

補足

iPhone7, Safariで検証しています。

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

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

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

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

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

guest

回答1

0

ベストアンサー

試行錯誤の内情がわかりませんが、前の質問も含めて考えると、未確定文字の保持はできているということですかね?
であればjQuery側で非表示になっているコントロールを取得して、valueにその保持した文字列を入れてやってから送信すればrequired突破できたりしませんか?
・フォーム送信ボタン押下
・jQueryでイベントを取得
・入力欄の状態(表示/非表示)を取得
・非表示であれば保持している文字列を入力欄のvalueに詰めて
・form.submit()
てきな

投稿2018/06/26 08:22

perpouh

総合スコア299

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

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

kotahayashi

2018/06/27 03:33

どのような試行錯誤をしたか、記述に不備があり申し訳ございません。 未確定文字の保持はできておりまして、ご回答の通り フォーム送信ボタンでイベント発火→保持している文字列を入力欄のvalueに入れる→その後にform.submit() で解決しました。ありがとうございました。
perpouh

2018/06/27 07:49

おめでとうございます。頑張ってください
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問