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

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

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

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

jQuery

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

Q&A

解決済

3回答

1747閲覧

複数のセレクトボックスに配列から作成したoptionを入れたい

R_suzuki766

総合スコア23

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2019/06/07 03:23

連想配列から作成したoptionを複数のセレクトボックスに入れたいのですが、
最後のselectのみ追加され、他のselectには追加されません。
mapをeachにしてもやってみましたが、結果は変わりませんでした。

ソースコード

HTML

1<p>optionが入らない</p> 2<select></select> 3<br> 4<br> 5<p>optionが入る</p> 6<select></select>

javascript

1$(function () { 2 let array = { 3 1: 'たろう', 4 2: 'はなこ', 5 3: 'みか' 6 }; 7 let options = $.map(array, function (name, id) { 8 return $("<option>", { 9 value: id, 10 text: name 11 }); 12 }); 13 14 $('select').map(function () { 15 $(this).find("option").remove(); 16 $(this).append( 17 $("<option>", { value: "", text: "選択してください" }) 18 ); 19 $(this).append(options); 20 $(this).attr("disabled", false); 21 }); 22});

Codepen: https://codepen.io/r_suzuki766/pen/XwLazE

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

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

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

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

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

guest

回答3

0

ベストアンサー

appendを誤解しているからですね
最初のselectにappendされたoptionは次のselectにappendされたときに移動されます。
もし処理するならoptions配列内のoptionをcloneしてappendすることです。

javascript

1<script> 2$(function () { 3 let array = { 4 1: 'たろう', 5 2: 'はなこ', 6 3: 'みか' 7 }; 8 let options = $.map(array, function (name, id) { 9 return $("<option>", { 10 value: id, 11 text: name 12 }); 13 }); 14 $('select').find("option").remove().end().append( 15 $("<option>", { value: "", text: "選択してください" }) 16 ).prop("disabled", false); 17 options.forEach(function(x){$('select').append(x.clone())}); 18}); 19</script> 20<select></select> 21<select></select> 22<select></select>

修正版

cloneしなくてもeachやmapをしなければ行ける

$('select').find("option").remove().end().append( $("<option>", { value: "", text: "選択してください" }) ).append(options).prop("disabled", false);

投稿2019/06/07 03:44

編集2019/06/07 04:29
yambejp

総合スコア114843

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

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

yambejp

2019/06/07 03:47

mapとかattrとかの使い方もおかしいところがあったので修正してあります
R_suzuki766

2019/06/07 04:17

回答に加え修正まで丁寧にありがとうございます。こちらの方法で解決いたしました。 おっしゃる通りappendの仕様を誤解していました。ありがとうございます。
guest

0

単に入れるだけならmapしなくてもいい気もしますが

js

1$('select').find("option").remove(); 2$('select').append( 3 $("<option>", { value: "", text: "選択してください" }) 4); 5$('select').append(options); 6$('select').attr("disabled", false);

投稿2019/06/07 04:24

m.ts10806

総合スコア80850

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

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

m.ts10806

2019/06/07 04:25

あ、解決でしたか。失礼。
R_suzuki766

2019/06/07 05:06

解決済みにするのを忘れておりました。すいません。 map使う必要ないんですね…!ありがとうございます。
guest

0

削除中・・・・・・・

投稿2019/06/07 04:28

編集2019/06/07 05:04
yambejp

総合スコア114843

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問