使用Ryan Fait的“自定义表单元素”时“全部检查”功能

时间:2012-07-05 20:43:58

标签: javascript jquery forms checkbox

我使用Ryan Fait的自定义表单元素制作了一个简单的表单。现在我正在尝试实现“全部检查”/“取消全部检查”功能。

除了用户必须单击两次按钮以获得所需结果外,我的工作主要是什么。我有一种感觉,我需要从自定义表单元素脚本中调用此函数,但我不知道如何。

我正在使用JQuery,自定义表单元素(http://ryanfait.com/resources/custom-checkboxes-and-radio-buttons/custom-form-elements.js),并且:

<script type = "text/javascript">
function cboxToggle(group, action) {
for( var i=0, len = group.length; i < len; i++) {
group[i].checked = action;
}
}

</script>

我的HTML:

<form name="myname" action="checkboxes.asp" method="post">
<input type = "button" value = " CHECK ALL" onclick = "cboxToggle(check_list, !this.checked)"><br>
<input type = "button" value = " UNCHECK ALL" onclick = "cboxToggle(check_list, this.checked)"><br>

<p><input type="checkbox" name="check_list" value="1" class="styled" />Option 1 </p> 
<p><input type="checkbox" name="check_list" value="2" class="styled" />Option 2 </p>
<p><input type="checkbox" name="check_list" value="3" class="styled" />Option 3 </p>
</form>

任何帮助将不胜感激 - 谢谢!

2 个答案:

答案 0 :(得分:0)

如果您正在使用jQuery,那么为什么不充分发挥它的潜力呢?这也意味着,没有内联代码......首先在你的按钮上添加一个id。然后确保您正确使用群组,而不是group而是group[]。然后使用此代码,它应该工作:

var ckToggle = function (group, action) {
  $('[name="'+ group +'"]').prop('checked', action)
}

$('#buttonAll').click(function(){ ckToggle('check_list[]', true) })
$('#buttonNone').click(function(){ ckToggle('check_list[]', false) })

答案 1 :(得分:0)