例えば、以下のようにラジオボタンが3つあって、
<input type="radio" name="color"> 赤
<input type="radio" name="color"> 青
<input type="radio" name="color" onXxx="check()"> 黄
黄がチェックされた時と、チェックが外れた時に、動作するイベントハンドラって可能ですか?
↓check関数の例
function check() {
if (略) {
alert('「黄」がチェックされました');
} else {
alert('「黄」がチェックが外れました');
}
}
onchangeも、onfocus+onblurも、微妙な動きになってしまいます。
やはり、全てのラジオボタンの要素にclickイベントハンドラ追加してやらないといけないのでしょうか?
No.1ベストアンサー
- 回答日時:
<html>
<input type="radio" name="color" id="r"> 赤
<input type="radio" name="color" id="b"> 青
<input type="radio" name="color" id="y"> 黄
<script>
window.onload = function(){
window.document.onclick = check;
}
function check(e) {
var o=e?e.target:event.srcElement;
if(o.tagName !='INPUT' && o.type !='radio') return;
if(document.getElementById('r').checked) alert('赤になった'); else alert('赤はずれ');
if(document.getElementById('b').checked) alert('青になった'); else alert('青はずれ');
if(document.getElementById('y').checked) alert('黄になった'); else alert('黄はずれ');
}
</script>
ご回答ありがとうございます。
なるほど!document全体にクリックを登録して、イベントがラジオボタンなら、とやってるんですね。
ラジオボタン分ループしてイベントリスナーを登録するより、行数が減りました。JavaScript勉強せねば。。
ありがとうございましたー!
No.2
- 回答日時:
単純にフラグで管理してみては?
<script>
window.onload=function(){
colorFlg="";
var tags=document.getElementsByTagName("input")
for(var i=0;i<tags.length;i++){
if(tags[i].name=="color"){
tags[i].onclick=function(){
if(this.value=="y") alert("「黄」がチェックされました");
else if(colorFlg=="y") alert("「黄」がチェックが外れました");
colorFlg=this.value;
}
}
}
}
</script>
<input type="radio" name="color" value="r"> 赤
<input type="radio" name="color" value="b"> 青
<input type="radio" name="color" value="y"> 黄
ご回答ありがとうございます。
なるほど。こちらの方が正統的な感じがしますね。
「黄」がチェックされているかどうかが知りたいだけなので、
少し無駄なイベントが増えますが、以下のようにしようと思います。
<script>
window.onload = function() {
var tags = document.getElementById("colors").getElementsByTagName("input");
for (var i = 0; i < tags.length; i++) {
tags[i].onclick = function() {
if (this.value == "y") {
alert("「黄」がチェックされました");
} else {
alert("「黄」がチェックが外れました");
}
}
}
}
</script>
<div id="colors">
<input type="radio" name="color"> 赤
<input type="radio" name="color"> 青
<input type="radio" name="color" value="y"> 黄
</div>
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- HTML・CSS ただいま勉強始めたての初心者です。フォームを縦並べにしたいです。 2 2022/11/20 17:18
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- HTML・CSS CSS のみのタブ切り替えについて 1 2023/01/11 16:47
- その他(プログラミング・Web制作) seleniumbasic chrome操作について 1 2023/03/29 15:40
- PHP $_SESSIONについて教えて下さい。 2 2023/03/02 09:18
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- HTML・CSS 私の能力からして間違っていないような気がします。 4 2022/09/30 13:24
このQ&Aを見た人はこんなQ&Aも見ています
-
「環境が人を育てる」って本当?環境によって人格や生き方は本当に変わるのか
環境が人生に与える影響は実際どれほどのものなのか、専門家の田宮由美さんに伺った。
-
チェックボックスのON/OFFに連動してラジオボタンのdisabledを解除
JavaScript
-
JavaScript window.openで開く際、そのwindowの背景色を指定したい
JavaScript
-
リクエストに応じたselectedの初期値設定方法
Java
-
-
4
ラジオボタンの選択肢をサーブレットで取得するには?
Java
-
5
servletからjspへオブジェクトの配列情報を送る方法
Java
-
6
Servletでテキストボックスに入力された内容を追記したい。
Java
-
7
JavaScriptでラジオボタンのチェックをはずす。
JavaScript
-
8
Selectの中身をfor文で入れる
JavaScript
-
9
boolean型のフィールドとゲッターメソッドの命名について
Java
-
10
exeファイルの中身を見ることは可能ですか?
フリーソフト
-
11
Java-jspの画面入力値保持について
Java
-
12
formで特定のinputを送信しないようにしたい
JavaScript
-
13
【jsp/Java】チェックボックスの状態をリロード時に保持したいです。
JavaScript
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ラジオボタンにタブインデック...
-
ラジオボタンでdisabledとchecked
-
javascriptで削除確認の画面に...
-
データベースの値を判断してラ...
-
ラジオボタンで選択した項目の...
-
Javascriptを使って動的にラジ...
-
チェックボックスとテキストボ...
-
ラジオボタン未チェックの場合...
-
ラジオボタンで診断テストを作...
-
リンク文字クリックでラジオボ...
-
診断サイトの作り方
-
ラジオボタンで入力フィールド...
-
ラジオボタンのチェックが外れ...
-
チェックされた項目を、指定さ...
-
【診断テストの作り方】結果に...
-
EXCEL VBA:IEの操作であるラジ...
-
JavaScriptでラジオボタンのチ...
-
return trueとreturn falseの用...
-
プルダウン 項目が多いので先頭...
-
フォームの内容でリンク先URLの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ラジオボタンにタブインデック...
-
データベースの値を判断してラ...
-
ラジオボタンのチェックが外れ...
-
ラジオボタンの値でリンク先を...
-
javascript作成してます。ラジ...
-
ラジオボタン未チェックの場合...
-
チェックされたラジオボタンに...
-
チェックボックスのON/OFFに連...
-
jQueryで複数のラジオボタンを処理
-
radio選択をクッキーに保存させ...
-
フォームPOST後「戻る」時のチ...
-
JavaScript ラジオボタン デ...
-
JavaScriptでラジオボタンのチ...
-
VBA IE ラジオボタンに...
-
ラジオボタンのリセット方法
-
js radioボタンの「name」を多...
-
ラジオボタンでdisabledとchecked
-
リセットボタンでクリアできな...
-
ラジオボタンで選択した項目の...
-
Javascriptを使って動的にラジ...
おすすめ情報