1
 <div ng-show="!login.SecQuestions && !login.ResetUser">
                <h3>Answer security questions</h3>
                <ul>
                    <li>
                        <label>Please answer the following question(s)</label>
                    </li>
                </ul>
                <ul>
                    <li>
                        *= required field
                    </li>
                </ul>

                <ul ng-repeat="Question in login.SecurityQuestions">
                    <li>
                        {{Question.Question}}
                    </li>
                    <li>
                        <ng-form name="SecQuestionForm" novalidate>
                            <textarea name="SecurityAnswer" ng-model="Question.Answer" type="text" required></textarea>
                            <span style="color:red" ng-if="SecQuestionForm.SecurityAnswer.$dirty" ng-show="SecQuestionForm.SecurityAnswer.$invalid">required.</span>
                        </ng-form>
                    </li>
                </ul>

                <ul>
                    <li>
                        <button class="primaryButton" ng-disabled="ResetNamePass.SecQuestionForm.$invalid" ng-click="Continue_2()">Continue</button>
                    </li>
                </ul>
            </div>

ng-Form 的动态验证 启用按钮不会验证所有三个必填字段,它的启用取决于最后一个 Textarea 的必需性。

错误截图

https://drive.google.com/folderview?id=0Bz2v151kdXv8fjNsc0VGLVpOOFNoRklCcTdZNjFkOWproEYteENJTUN1YUZUbHRVc3hNaFE&usp=sharing

4

4 回答 4

1

让我们想象一下,如果你有这样的表格

<form name='form'>
   <input name='name'></input>
   <button ng-disabled='!form.name'></button>
</form>

希望它有助于演示小提琴

于 2015-04-02T09:42:24.380 回答
1

将您的 ng-form 放在一个表单中,然后在按钮上添加条件以确保外部表单的有效性。

<form novalidate name='form1'>
    <ul ng-repeat="Question in login.SecurityQuestions">
                        <li>
                            {{Question.Question}}
                        </li>
                        <li>
                            <ng-form name="SecQuestionForm" novalidate>
                                <textarea name="SecurityAnswer" ng-model="Question.Answer" type="text" required></textarea>
                                <span style="color:red" ng-if="SecQuestionForm.SecurityAnswer.$dirty" ng-show="SecQuestionForm.SecurityAnswer.$invalid">required.</span>
                            </ng-form>
                        </li>
                    </ul>

                    <ul>
                        <li>
                            <button class="primaryButton" ng-disabled="!form1.$valid" ng-click="Continue_2()">Continue</button>
                        </li>
                    </ul>
</form>

仅当所有嵌套的 ng-forms 都有效时,外部形式才有效

于 2015-04-02T10:13:34.163 回答
0
 `<form name="frmsignIn" ng-submit="login()" novalidate >
  <span class="glyphicon glyphicon-user" ></span>
  <div>
  <label for="email" >Email</label>
   <input type="email" name="email" ng-model="userName" ng-required="true"/>
   <span ng-show="frmsignIn.email.$dirty && frmsignIn.email.$error.required">*</span><span ng-show="frmsignIn.email.$dirty && frmsignIn.email.$error.email">Invalid email address</span>
    </div>
   <div>
    <label for="password">Password</label>
   <input type="password" name="password" ng-model="password" ng-required="true"/>
  <span ng-show="frmsignIn.password.$dirty && frmsignIn.password.$error.required">*</span>
   </div>
   <div>

    <button  type="submit" ng-disabled="frmsignIn.$invalid"  >  {{buttonText}}</button>

   </div>
   <div>
    <span ng-show="showErrorMsg">Invalid Email Address/Password.Please try again.</span>
   </div>
    </form>`
于 2015-04-02T10:22:02.257 回答
0

angular - 开发者指南 - 表单

  <form name="form" class="css-form" novalidate>
  <div>
    Overwritten Email:
    <input type="email" ng-model="myEmail" overwrite-email name="overwrittenEmail" />
    <span ng-show="form.overwrittenEmail.$error.email">This email format is invalid!</span><br>
    Model: {{myEmail}}
    </div>
</form>
于 2015-04-02T10:10:14.587 回答