我使用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>
任何帮助将不胜感激 - 谢谢!
答案 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)