4

我有一个包含两个步骤的表格。我想做的是在继续下一步之前验证每个步骤;用户应该无法进入第 1 步的第 2 步的字段无效。

js fiddle: http: //jsfiddle.net/Egyhc/
下面你可以找到表单的简化版本:

<form>
  <div id="step1" style="display: block;">
    <label for="first_name">First Name</label>
    <input type="text" value="" name="first_name" id="FirstName"/>

    <label for="last_name">Last Name</label>
    <input type="text" value="" name="last_name" id="LastName"/>
  </div>


  <div id="step2" style="display: none;">
    <label for="first_name">Address</label>
    <input type="text" value="" name="address" id="Address"/> 
  </div>

  <a href="#" id="step1_btn">Continue to step 2</a>
  <input type="submit" id="submit_btn" value="Verstuur" style="display: none;" />
</form>

​</p>

$(function() {
  $('#step1_btn').click(function() {
    $('#step1').hide();
    $('#step2, #submit_btn').show();        
  });
});​

你们建议我如何实现这一目标?

4

1 回答 1

6

jQuery validate 有一个非常简洁的设置,可以让您忽略对隐藏字段的验证。因此,您可以处理步骤的显示/隐藏逻辑,并且为了验证,您可以这样做:

正如这表明:忽略隐藏

$("form").validate({
   ignore: ":hidden"
});

如果您需要检查除了默认表单提交之外的其他内容的验证,您可以使用如下valid方法:$("form").valid().

我注意到您的表单上没有任何验证类,所以我假设您正在其他地方处理它。万一你不是,你可以告诉 jQuery 通过 css 类来验证你的规则,如下所示:<input type="text" class="required digits"/>

在此处查看更多信息:http: //bassistance.de/2008/01/30/jquery-validation-plugin-overview/

于 2012-06-15T14:35:31.157 回答