![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
jQueryを最近使い始めました。
以下のようなことをしたいのですが、いいやり方が分かりません。
jQueryを使ってページの読み込み後すぐに、ラジオボタンにチェックを入れたいと思っています。
以下のようにすると実際にチェックが入りました。
HTML
<input type="radio" name="a" value="1" />
<input type="radio" name="a" value="2" />
jQuery
if(!$("input:radio[name=a]:checked").val()){
$("input:radio[name=a]:first").attr("checked" , "checked");
}
ラジオボタンが複数ある場合、上記のjQueryのnameの値を変えたものを増やしていけば対応できたのですが、ラジオボタンがたくさんある場合、同じようなスクリプトが何行も増えてしまいます。
うまく関数にする方法やその他よい対処法はないでしょうか。
<input type="radio" name="a" value="1" />
<input type="radio" name="a" value="2" />
<input type="radio" name="b" value="1" />
<input type="radio" name="b" value="2" />
<input type="radio" name="c" value="1" />
<input type="radio" name="c" value="2" />
…
if(!$("input:radio[name=a]:checked").val()){
$("input:radio[name=a]:first").attr("checked" , "checked");
}
if(!$("input:radio[name=b]:checked").val()){
$("input:radio[name=b]:first").attr("checked" , "checked");
}
if(!$("input:radio[name=c]:checked").val()){
$("input:radio[name=c]:first").attr("checked" , "checked");
}
…
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
多少面倒ですが、こんな考え方のものが便利かと…
document.ready時に以下の処理を行なう
document内のラジオボタンを全て取得
取得したボタンについて、それぞれ以下の処理を行なう
name属性を取得
同じname属性のラジオボタンを取得し // *1
checkedの要素が無いか、または値が有効で
なかったら、*1の最初の要素にcheckを入れる
少々処理に重複はありますが、まあ、ボタンの数がめちゃくちゃ多いわけでもないでしょうから。
ご提示のスクリプトが、document全体から同じnameのラジオボタンを取得するようになっていますので、(↑)も同様にしていますが、
実際は、*1の要素は「同じform内で同じname属性を持つラジオボタン」にしておいた方が良いと思われます。
formが複数あって、その中でたまたま同じnameのラジオボタンがある場合を考えてみればわかるかと。
No.1
- 回答日時:
いくつか方法がありますが
1)ループ(繰り返し)処理を書く
jQueryのname部分を変数にしてループ処理
2)デフォルトでcheckが入るものに一定のルールがあればそれで指定
例えば常にvalue=1のものにcheck、といったルールがあるならば。
3)一定のルールがなければclassで
class="cheked" のついたものにcheckをつける、とjQueryに書き、
HTML側にはデフォルトでcheckをいれたいものにそのclassをつける
3が楽かなと思いますがいかがでしょう
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- HTML・CSS ただいま勉強始めたての初心者です。フォームを縦並べにしたいです。 2 2022/11/20 17:18
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- HTML・CSS CSS のみのタブ切り替えについて 1 2023/01/11 16:47
- PHP $_SESSIONについて教えて下さい。 2 2023/03/02 09:18
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- その他(プログラミング・Web制作) seleniumbasic chrome操作について 1 2023/03/29 15:40
- PHP 入力した部分を表示させたまま(保持)するにはどうすれば良いでしょうか? 1 2023/01/25 11:14
- JavaScript javascriptで移動ボタンを押した際に遷移するボタンを追記したい 1 2022/11/29 03:02
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
- JavaScript Javascript初心者|jQueryの.val()で値を取得し複数の要素を連結させる方法知りたい 2 2022/06/02 12:06
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ラジオボタンにタブインデック...
-
nameにハイフンを入れてラジオ...
-
Javascriptを使って動的にラジ...
-
jQuery 変数の使い方について
-
任意のinput要素同士の連動につ...
-
Jvasvriptのlengthで個数が取得...
-
ラジオボタンによる有効なボタ...
-
診断サイトの作り方
-
2項目計算って可能でしょうか?
-
ラジオボタンの分岐方法に関して
-
ラジオボタンを使った簡単なア...
-
jsでラジオボタンによって表示...
-
データベースの値を判断してラ...
-
サイト内にGoogleサイトを表示...
-
ラジオボタンのチェックが外れ...
-
特定のラジオボタンが選択され...
-
チェックボックスのON/OFFに連...
-
JavaScriptでラジオボタンのチ...
-
return trueとreturn falseの用...
-
プルダウン 項目が多いので先頭...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ラジオボタンにタブインデック...
-
データベースの値を判断してラ...
-
ラジオボタンのチェックが外れ...
-
ラジオボタンの値でリンク先を...
-
javascript作成してます。ラジ...
-
Jvasvriptのlengthで個数が取得...
-
ラジオボタンのValueを受け取り...
-
チェックされたラジオボタンに...
-
ラジオボタンの分岐方法に関して
-
ラジオボタンのリセット方法
-
ラジオボタンでdisabledとchecked
-
フォームPOST後「戻る」時のチ...
-
ラジオボタンのチェック数に応...
-
アンダーバーのname値は取得で...
-
ラジオボタンを使って、検索ペ...
-
ラジオボタン未チェックの場合...
-
リセットボタンでクリアできな...
-
javascriptによる動的なリンク...
-
javascriptでのアラート表示
-
【診断テストの作り方】結果に...
おすすめ情報