Angular JS:在提交之前验证表单字段

时间:2013-03-31 17:16:53

标签: javascript angularjs validation

我正在构建一个具有两步形式的Angular JS应用程序。它实际上只是一种形式,但是当用户单击“下一步”按钮并使用“步骤”时,使用JavaScript隐藏第一个面板并显示第二个面板。我已在步骤1中的某些字段上设置了“必需”验证,但显然,当用户点击“下一步”按钮时,它们不会得到验证......当在步骤2结束时单击“提交”按钮时,它们会得到验证。

当点击“下一步”按钮时,有什么方法可以告诉角度来验证表单中的字段吗?

1 个答案:

答案 0 :(得分:71)

我建议使用子表格。 AngularJS支持将一个表单放在另一个表单中,并且有效性从下层传播到上层;

以下是示例:http://plnkr.co/edit/SruBmlGZZtbwiU8cktAp?p=preview

以下是一些代码,您可以掌握这个想法:

  <form name='myform' ng-init="step = 1">
    <div ng-show="step==1">
      <h3>Step 1: Enter some general info</h3>
      <div ng-form='step1form'>
        Name: <input ng-model="name" required>
      </div>
      <button ng-disabled="!step1form.$valid" ng-click="step = 2">Next</button>
    </div>

    <div ng-show="step==2">
      <h3>Step 2: Final info</h3>
      <div ng-form="step2form">
          Phone: <input ng-model="phone" required>
      </div>
      <button  ng-click="step = 1">Prev</button>
      <button ng-disabled="!myform.$valid" ng-click="submit()">Submit</button>
    </div>
    <div>
      Validation status:
      <div> Whole form valid? {{myform.$valid}} </div>
      <div> Step1 valid? {{step1form.$valid}} </div>
      <div> Step2 valid? {{step2form.$valid}} </div>
    </div>
  </form>
相关问题