回答:
Value属性の値を取得するには、次のようにします。
$("input[type='checkbox']").val();
または、class
またはid
を設定している場合は、次のことができます。
$('#check_id').val();
$('.check_class').val();
ただし、これはチェックされるかどうかにかかわらず同じ値を返します。これは、送信されたフォームの動作とは異なるため、混乱を招く可能性があります。
チェックされているかどうかを確認するには、次のようにします。
if ($('#check_id').is(":checked"))
{
// it is checked
}
$($0).val()
Chromeで、そしてチェックを外し、チェックボックス、答えはそれがチェックされていないにもかかわらず、「上」です。しかし$($0).is(":checked")
、正しい値を返します。
[type="checkbox"]
は、最新のブラウザーでよりも優れたパフォーマンスを発揮します:checkbox
。
$('#check_id').val();
ために$('#check_id').is(":checked");
値がtrueまたはfalseを返します。
これらの2つの方法は機能しています。
$('#checkbox').prop('checked')
$('#checkbox').is(':checked')
(ありがとう@mgsloan)$('#test').click(function() {
alert("Checkbox state (method 1) = " + $('#test').prop('checked'));
alert("Checkbox state (method 2) = " + $('#test').is(':checked'));
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
Check me: <input id="test" type="checkbox" />
この小さなソリューションを試してください:
$("#some_id").attr("checked") ? 1 : 0;
または
$("#some_id").attr("checked") || 0;
チェックボックスの値を取得する唯一の正しい方法は次のとおりです
if ( elem.checked )
if ( $( elem ).prop( "checked" ) )
if ( $( elem ).is( ":checked" ) )
jQueryのWebサイトの公式ドキュメントで説明されています。残りのメソッドはチェックボックスのプロパティとは何の関係もありません。属性をチェックしています。つまり、ロードされたときのチェックボックスの初期状態をテストしています。要するに:
elem.checked
)か$(elem).prop("checked")
、jQueryに依存したい場合に使用できます。$(elem).is(":checked")
です。答えは誤解を招く可能性があります。以下を確認してください:
.is(":checked")
そして.prop(":checked")
wは/ jQueryの1.10.0私のために同じように働いている
$('#checkbox_id').val();
$('#checkbox_id').is(":checked");
$('#checkbox_id:checked').val();
jQuery(".checkboxClass").click(function(){
var selectedCountry = new Array();
var n = jQuery(".checkboxClass:checked").length;
if (n > 0){
jQuery(".checkboxClass:checked").each(function(){
selectedCountry.push($(this).val());
});
}
alert(selectedCountry);
});
//By each()
var testval = [];
$('.hobbies_class:checked').each(function() {
testval.push($(this).val());
});
//by map()
var testval = $('input:checkbox:checked.hobbies_class').map(function(){
return this.value; }).get().join(",");
//HTML Code
<input type="checkbox" value="cricket" name="hobbies[]" class="hobbies_class">Cricket
<input type="checkbox" value="hockey" name="hobbies[]" class="hobbies_class">Hockey
デモの例
この質問がjQueryソリューションを求めているという事実にもかかわらず、誰もそれを言及していないので、ここに純粋なJavaScriptの答えがあります。
要素を選択してchecked
プロパティにアクセスするだけです(ブール値を返します)。
var checkbox = document.querySelector('input[type="checkbox"]');
alert(checkbox.checked);
<input type="checkbox"/>
change
イベントをリッスンする簡単な例を以下に示します。
var checkbox = document.querySelector('input[type="checkbox"]');
checkbox.addEventListener('change', function (e) {
alert(this.checked);
});
<input type="checkbox"/>
チェックされた要素を選択するには、:checked
疑似クラス(input[type="checkbox"]:checked
)を使用します。
以下は、チェックされたinput
要素を反復処理し、チェックされた要素の名前のマップされた配列を返す例です。
var elements = document.querySelectorAll('input[type="checkbox"]:checked');
var checkedElements = Array.prototype.map.call(elements, function (el, i) {
return el.name;
});
console.log(checkedElements);
checked
、ネイティブDOM要素でプロパティに簡単にアクセスできる場合、このような些細な場合でもjQueryを回避できることを示すことでした。このような質問/回答を検索する人の一部は、jQueryが必要でない場合があることを一般に認識していません。言い換えれば、狭心な人々はこの回答の対象となる人口統計ではありません。
チェックされたcheckboxexの値を取得するにはjquery
:
var checks = $("input[type='checkbox']:checked"); // returns object of checkeds.
for(var i=0; i<checks.length; i++){
console.log($(checks[i]).val()); // or do what you want
});
でpure js
:
var checks = document.querySelectorAll("input[type='checkbox']:checked");
for(var i=0; i<checks.length; i++){
console.log(checks[i].value); // or do what you want
});
$('.class[value=3]').prop('checked', true);
最善の方法は $('input[name="line"]:checked').val()
また、選択したテキストを取得できます $('input[name="line"]:checked').text()
ラジオボタンの入力に値の属性と名前を追加します。すべての入力に同じ名前属性があることを確認してください。
<div class="col-8 m-radio-inline">
<label class="m-radio m-radio-filter">
<input type="radio" name="line" value="1" checked> Value Text 1
</label>
<label class="m-radio m-radio-filter">
<input type="radio" name="line" value="2"> Value Text 2
</label>
<label class="m-radio m-radio-filter">
<input type="radio" name="line" value="3"> Value Text 3
</label>
</div>
<script type="text/javascript">
$(document).ready(function(){
$('.laravel').click(function(){
var val = $(this).is(":checked");
$('#category').submit();
});
});
<form action="{{route('directory')}}" method="post" id="category">
<input type="hidden" name="_token" value="{{ csrf_token() }}">
<input name="category" value="{{$name->id}}" class="laravel" type="checkbox">{{$name->name}}
</form>
2018年現在、APIは長年にわたって変化しているため、注意が必要です。removeAttrは廃止され、もう機能していません!
チェックボックスをチェックまたはチェック解除するjquery:
悪い、もう動かない。
$('#add_user_certificate_checkbox').removeAttr("checked");
$('#add_user_certificate_checkbox').attr("checked","checked");
代わりに、次のことを行う必要があります。
$('#add_user_certificate_checkbox').prop('checked', true);
$('#add_user_certificate_checkbox').prop('checked', false);
$("input:checkbox")
。また、クラスセレクタにタイプミスがあるようです...