使用JQuery Validation Plugin进行条件验证 [英] Conditional Validation using JQuery Validation Plugin
问题描述
我有一个简单的html表单,我已经使用JQuery Validation插件添加了验证。我让它适用于需要值的单个字段。我现在需要对其进行扩展,以便如果用户对问题回答是,则必须在详细信息字段中输入内容,否则详细信息字段可以留空。我正在使用单选按钮显示是/否。这是我完整的html表单 - 我不知道从哪里开始:
I have a simple html form that I've added validation to using the JQuery Validation plugin. I have it working for single fields that require a value. I now need to extend that so that if a user answers Yes to a question they must enter something in the Details field, otherwise the Details field can be left blank. I'm using radio buttons to display the Yes/No. Here's my complete html form - I'm not sure where to go from here:
<script type="text/javascript" charset="utf-8">
$.metadata.setType("attr", "validate");
$(document).ready(function() {
$("#editRecord").validate();
});
</script>
<style type="text/css">
.block { display: block; }
form.cmxform label.error { display: none; }
</style>
</head>
<body>
<div id="header">
<h1>
Questions</h1>
</div>
<div id="content">
<h1>
Questions Page 1
</h1>
</div>
<div id="content">
<h1>
</h1>
<form class="cmxform" method="post" action="editrecord.php" id="editRecord">
<input type="hidden" name="-action" value="edit">
<h1>
Questions
</h1>
<table width="46%" class="record">
<tr>
<td width="21%" valign="top" class="field_name_left"><p>Question 1</p></td>
<td width="15%" valign="top" class="field_data">
<label for="Yes">
<input type="radio" name="Question1" value="Yes" validate = "required:true" /> Yes
</label>
<label for="No">
<input type="radio" name="Question1" value="No" /> No
</label>
<label for="Question1" class="error">You must answer this question to proceed</label>
</td>
<td width="64%" valign="top" class="field_data"><strong>Details:</strong>
<textarea id = "Details1" class="where" name="Details1" cols="25" rows="2"></textarea></td>
</tr>
<tr>
<td valign="top" class="field_name_left">Question 2</td>
<td valign="top" class="field_data">
<label for="Yes">
<input type="radio" name="Question2" value="Yes" validate = "required:true" /> Yes
</label>
<label for="No">
<input type="radio" name="Question2" value="No" /> No
</label>
<label for="Question2" class="error">You must answer this question to proceed</label>
</td>
<td valign="top" class="field_data"><strong>Details:</strong>
<textarea id = "Details2" class="where" name="Details2" cols="25" rows="2"></textarea> </td>
</tr>
<tr class="submit_btn">
<td colspan="3">
<input type="submit" name="-edit" value="Finish">
<input type="reset" name="reset" value="Reset"> </td>
</tr>
</table>
</form>
</div>
</body>
</html>
推荐答案
在< textarea>上;
元素,添加依赖关系表达式对于 required
,例如问题1,执行此操作:
On your <textarea>
elements, add a dependency expression for required
, for example for question 1, do this:
validate="required:'input[name=Question1][value=Yes]:checked'"
如果 $('input [name = Question1} ] [value = Yes]:选中')。长度> 0
然后该字段是必填字段,因此如果选中是,则需要:)
This says if $('input[name=Question1][value=Yes]:checked').length > 0
then the field is required, so if Yes is checked, it's required :)
这篇关于使用JQuery Validation Plugin进行条件验证的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!