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

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

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

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

Q&A

解決済

1回答

6686閲覧

JavaScriptでradioボタンで選択して背景色を変える(for loop を使って)

margutta

総合スコア34

JavaScript

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

0グッド

0クリップ

投稿2016/10/15 16:49

###前提・実現したいこと
JavaScript で、ラジオボタンを使って、背景色を変更するとき、個々のラジオボタンにid をふって特定するのではなく、document.getElementsByName('color')のようにして、配列に格納し、クリックされたラジオボタンのvalue に設定された背景色をページに設定するように、配列とループとif を使ってできないかなといろいろ試してみたのですが、まだ、理解が浅いようでうまくいきません。

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

エラーメッセージ

###該当のソースコード

JavaScript

1IDをふれば書ける 2<body> 3<form id="myForm"> 4 <input type="radio" name ="color" id="g" value="green">green 5 <input type="radio" name ="color" id="r" value="red">red 6</form> 7 8<script> 9 g.onclick =function(){document.body.style.background = g.value;} 10 r.onclick =function(){document.body.style.background = r.value;} 11</script> 12</body> 13</html> 14 15○ 配列に入れて1つづつ取り出すなら書ける 16<body> 17<form id="myForm"> 18 <input type="radio" name ="color" value="green">green 19 <input type="radio" name ="color" value="red">red 20</form> 21 22<script> 23 var c = document.getElementsByName('color'); 24 c[0].onclick =function(){document.body.style.background = c[0].value;} 25 c[1].onclick =function(){document.body.style.background = c[1].value;} 26</script> 27 28**<ここが知りたい!>** 29for を使ってラジオボタンがチェックされているかどうか順次チェックし、 30○ チェックされていたら背景色を、選択されているラジオボタンの値に変えるという風に書きたい 31と思い、↓のように、書いてみたりしてみたのですが、うまくいきません.... 32 33 34<script> 35var c = document.getElementsByName('color'); 36for(i=0; i<c.length; i++){ 37 c[i].onclick= function(){document.body.style.backcground = c[i].value; 38 } 39 } 40 41</script> 42 43注 本当は、 if(c[i].checked) のように書きたい....

###試したこと
課題に対してアプローチしたことを記載してください

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

guest

回答1

0

ベストアンサー

onclick を実行する時点で変数 ic.length になっているからそうなりますので、let か即時関数で処理しましょう。

JavaScript

1var c = document.getElementsByName( 'color' ); 2for ( let i=0; i<c.length; i++ ) { 3 c[ i ].onclick = function() { 4 document.body.style.backgroundColor = c[ i ].value; 5 } 6} // let 7```**動くサンプル:**[https://jsfiddle.net/6x1o1fp7/](https://jsfiddle.net/6x1o1fp7/) 8 9 10```JavaScript 11var c = document.getElementsByName( 'color' ); 12for ( var i=0; i<c.length; i++ ) { 13 ( function( k ) { c[ k ].onclick = function() { 14 document.body.style.backgroundColor = c[ k ].value; 15 } } )( i ); 16} // 即時関数 17```**動くサンプル:**[https://jsfiddle.net/6x1o1fp7/1/](https://jsfiddle.net/6x1o1fp7/1/)

投稿2016/10/15 17:13

kei344

総合スコア69407

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

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

margutta

2016/10/16 04:42

丁寧な回答を付けていただきありがとうございました。 即時関数の最後のかっこは()即時に実行されるための飾りではないこと、パラメータを格納できることを初めて知りました。 また、let の威力を知り、目から鱗でした。本当にありがとうございます。 let と var の使い分けについて、まだよくわかっていないので、整理してまた、質問をさせていただきたいと思います。 貴重なお時間を割いていただき、また、惜しみなく知識を授けてくださりありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問