ラジオボタンのカスタムデータ属性を取得し、特定の値の場合はチェックさせない方法
2023/10/25
ASPを使用したサイトで特定のradioボタンは選択不可にしたいというケースがあった。通常の場合だとdisabled属性指定で対応したいが当該formはASP側で制御されており変更が難しいという状況。幸いなことにradioボタンにカスタムデータ属性が設定されており、そちらのデータで選択可否を判断できたので対応方法をメモ。
ソースコード
<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>test</title>
</head>
<body>
<form>
<label>
<input type="radio" name="radio_1" value="1" data-flg="0">チェック不可
</label>
<label>
<input type="radio" name="radio_1" value="2" data-flg="1">チェック可
</label>
<label>
<input type="radio" name="radio_1" value="3" data-flg="1">チェック可
</label>
</form>
<script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.js"></script>
<script type="text/javascript">
$(function(){
$('input[name="radio_1"]').on('click', function(){
if( !$(this).data('flg') ){
return false;
}
});
});
</script>
</body>
</html>
data-flgが0の場合は選択不可という挙動になる。尚、「return false」じゃなく「$(this).prop('checked', false)」で対応した場合、以下の違いがある。
「return false」の場合
チェック可のラジオボタンを選択→チェック不可のラジオボタンをクリックした際、チェック可のラジオボタンはチェックされたまま。
「$(this).prop('checked', false)」の場合
チェック可のラジオボタンを選択→チェック不可のラジオボタンをクリックした際、チェック可のラジオボタンはチェックが外れる。
関連記事
-
-
jQueryのanimate()でページスクロール後に他の処理を実行させる方法
jQueryのanimate()でページスクロール後に特定の要素を非表示にしたい ...
-
-
jQuery UI Datepickerで日本の祝祭日を表示
やりたかった事は、jQueryのカレンダーピッカーで 日本の祝祭日の色を変えると ...
-
-
jQueryでユーザーが編集可能な文字列をページ上に表示する際にエスケープする方法
GETパラメータを取得し、その内容をページ上に表示したいケースがあった。また、A ...
-
-
ライブラリ等を使用せずファイルをドラッグ&ドロップでアップロードする方法
formにドラッグ&ドロップでファイルをアップロードする機能を実装する場 ...
-
-
AjaxFileUploadで処理は実行できてもエラーが返る
AjaxFileUploadでPHPに通信し、サーバー側のPHPで処理は正常に実 ...