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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

1回答

314閲覧

Railsのフォームで、1つのメソッドに入っているパラメータを送信したい

uranus

総合スコア0

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2020/07/06 13:27

前提・実現したいこと

Railsで複数のドロップダウンリストから入力された値を送信したいです(うち1つしか入力できない想定)

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

https://codepen.io/momosetkn/pen/JMQKKM
をまねて

erb

1<div class="pulldownset"> 2 <%= f.label :city, class: 'label-required' %> 3 <select class="mainselect form-control"> 4 <option value="kobe">こうべ</option> 5 <option value="hokkaido">hokkaido</option> 6 </select> 7 <%= f.select :city, 8 [ 9 "神戸市", 10 "姫路市" 11 "加古川市" 12 ], 13 { prompt: "選択してください" }, { id: "kobe" } 14 %> 15 <%= f.select :city, 16 [ 17 "札幌市", 18 "旭川市" 19 "苫小牧市" 20 ], 21 { prompt: "選択してください" }, { id: "hokkaido" } 22 %> 23</div>

js

1document.addEventListener('DOMContentLoaded', function() { 2 var allSubBoxes = document.getElementsByClassName("subbox"); 3 for( var i=0 ; i<allSubBoxes.length ; i++) { 4 allSubBoxes[i].style.display = 'none'; 5 } 6 var mainBoxes = document.getElementsByClassName('pulldownset'); 7 for( var i=0 ; i<mainBoxes.length ; i++) { 8 var mainSelect = mainBoxes[i].getElementsByClassName("mainselect"); 9 mainSelect[0].onchange = function () { 10 var subBox = this.parentNode.getElementsByClassName("subbox"); 11 for( var j=0 ; j<subBox.length ; j++) { 12 subBox[j].style.display = 'none'; 13 } 14 if( this.value ) { 15 var targetSub = document.getElementById( this.value ); 16 targetSub.style.display = 'inline'; 17 } 18 } 19 } 20 });

上記のようなコードになったのですが、北海道の市を選択した際は問題なくパラメータが入るのですが、神戸を選択した際は空になってしまいます。
おそらく同じ Hoge.cityに値を入れようとして、加古川市などを選択した際はあとから 北海道のほうの何も入っていないというデータで上書きされてしまうからだと思うのですが、回避する方法はありますでしょうか?

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

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

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

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

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

guest

回答1

0

f.select :city が複数回あります。
こうすると同じ name の入力要素ができます。
その場合 formは一番最後のものだけ送信します。
なので、どこをどう選ぼうと、北海道の選択結果が送信されます。
対策は

全部を一つのcelectに収める
都道府県を選択したらcityの選択肢が変わるようにする
都道府県毎に city01 の様に変える

でしょうか

投稿2020/07/06 22:42

winterboum

総合スコア23329

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問