我希望一个事件在选中/未选中复选框时触发客户端:
$('.checkbox').click(function() {
if ($(this).is(':checked')) {
// Do stuff
}
});
基本上,我希望页面上的每个复选框都发生这种情况。这种触发点击并检查状态的方法可以吗?
我在想必须有一种更清洁的jQuery方式。有人知道解决方案吗?
我希望一个事件在选中/未选中复选框时触发客户端:
$('.checkbox').click(function() {
if ($(this).is(':checked')) {
// Do stuff
}
});
基本上,我希望页面上的每个复选框都发生这种情况。这种触发点击并检查状态的方法可以吗?
我在想必须有一种更清洁的jQuery方式。有人知道解决方案吗?
Answers:
绑定到change
事件而不是click
。但是,您可能仍然需要检查是否已选中该复选框:
$(".checkbox").change(function() {
if(this.checked) {
//Do stuff
}
});
绑定到 删除评论change
事件click
而不是事件的主要好处是,并非所有对复选框的单击都会导致其更改状态。如果只想捕获导致复选框更改状态的事件,则需要适当命名的change
事件。
另请注意,我曾经 this.checked
而不是将元素包装在jQuery对象中并使用jQuery方法,只是因为直接访问DOM元素的属性更短,更快。
编辑(请参阅评论)
要获得所有复选框,您有两个选择。您可以使用:checkbox
伪选择器:
$(":checkbox")
或者您可以使用属性等于选择器:
$("input[type='checkbox']")
$(this).is(':checked')
。我以为change
如果要检测键盘上的更改(制表符,敲击空格)必须使用该事件,但是令人惊讶的是,它click
也检测到不是鼠标单击所引起的更改,不确定是不是jQuery,jsfiddle.net / mendesjuan / E39sz
click
,change
或任何页面上的所有复选框可能会导致性能问题(depepending上复选框的量)。尝试绑定到父元素或文档并捕获冒泡事件,即$('form').on('change', ':checkbox', function(){ //stuff });
为了将来对此处遇到困难的任何人提供参考,如果您动态添加复选框,则上面正确的可接受答案将不起作用。您将需要利用事件委托,它允许父节点从特定后代捕获冒泡事件并发出回调。
// $(<parent>).on('<event>', '<child>', callback);
$(document).on('change', '.checkbox', function() {
if(this.checked) {
// checkbox is checked
}
});
注意,几乎没有必要将其document
用于父选择器。而是选择一个更特定的父节点,以防止将事件传播到太多级别。
以下示例显示了动态添加的dom节点的事件如何不触发先前定义的侦听器。
$postList = $('#post-list');
$postList.find('h1').on('click', onH1Clicked);
function onH1Clicked() {
alert($(this).text());
}
// simulate added content
var title = 2;
function generateRandomArticle(title) {
$postList.append('<article class="post"><h1>Title ' + title + '</h1></article>');
}
setTimeout(generateRandomArticle.bind(null, ++title), 1000);
setTimeout(generateRandomArticle.bind(null, ++title), 5000);
setTimeout(generateRandomArticle.bind(null, ++title), 10000);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<section id="post-list" class="list post-list">
<article class="post">
<h1>Title 1</h1>
</article>
<article class="post">
<h1>Title 2</h1>
</article>
</section>
尽管此示例显示了事件委托的用法,以捕获特定节点的事件(h1
在这种情况下),并为此类事件发出回调。
$postList = $('#post-list');
$postList.on('click', 'h1', onH1Clicked);
function onH1Clicked() {
alert($(this).text());
}
// simulate added content
var title = 2;
function generateRandomArticle(title) {
$postList.append('<article class="post"><h1>Title ' + title + '</h1></article>');
}
setTimeout(generateRandomArticle.bind(null, ++title), 1000); setTimeout(generateRandomArticle.bind(null, ++title), 5000); setTimeout(generateRandomArticle.bind(null, ++title), 10000);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<section id="post-list" class="list post-list">
<article class="post">
<h1>Title 1</h1>
</article>
<article class="post">
<h1>Title 2</h1>
</article>
</section>
如果您打算仅将事件附加在已选中的复选框上(因此当未选中它们并在稍后再次选中时会触发事件),那么这就是您想要的。
$(function() {
$("input[type='checkbox']:checked").change(function() {
})
})
如果您打算将事件附加到所有复选框(已选中和未选中)
$(function() {
$("input[type='checkbox']").change(function() {
})
})
如果您希望仅在选中它们(未选中)时将其触发,则@James Allardice会在上方回答。
BTW input[type='checkbox']:checked
是CSS选择器。
$("input[type='checkbox']:not(:checked)")
$(document).ready(function () {
$(document).on('change', 'input[Id="chkproperty"]', function (e) {
alert($(this).val());
});
});
根据事件(点击事件)采取行动。
$('#my_checkbox').on('click',function(){
$('#my_div').hide();
if(this.checked){
$('#my_div').show();
}
});
如果没有事件,则根据当前状态采取措施。
$('#my_div').hide();
if($('#my_checkbox').is(':checked')){
$('#my_div').show();
}
试试这个jQuery验证
$(document).ready(function() {
$('#myform').validate({ // initialize the plugin
rules: {
agree: {
required: true
}
},
submitHandler: function(form) {
alert('valid form submitted');
return false;
}
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-validate/1.17.0/jquery.validate.js"></script>
<form id="myform" action="" method="post">
<div class="buttons">
<div class="pull-right">
<input type="checkbox" name="agree" /><br/>
<label>I have read and agree to the <a href="https://stackexchange.com/legal/terms-of-service">Terms of services</a> </label>
</div>
</div>
<button type="submit">Agree</button>
</form>
很简单,这就是我使用的方式:
jQuery的:
$(document).on('change', '[name="nameOfCheckboxes[]"]', function() {
var checkbox = $(this), // Selected or current checkbox
value = checkbox.val(); // Value of checkbox
if (checkbox.is(':checked'))
{
console.log('checked');
}else
{
console.log('not checked');
}
});
问候!