首页 文章

使用Angular-material验证表单

提问于
浏览
6

如何使用Angular-material验证表单,我需要两个功能:1)如果必填字段为空,请单击“提交时显示错误消息” . 2)如果表单字段无效,请勿发送帖子请求(避免提交) . 下一个代码避免提交,但是在单击时它不显示错误消息,仅当光标离开每个输入字段时 .

<form name="userForm">
<md-input-container>
    <input name="email" placeholder="Email" data-ng-model="vm.registerUserData.email" required />
    <div ng-messages="userForm.email.$error" ng-if='userForm.myControl.$dirty'>
      <div ng-message="required">This is required!</div>
    </div>
</md-input-container>

<md-input-container>
    <input name="Password" placeholder="Password" data-ng-model="vm.registerUserData.password" required />
     <div ng-messages="userForm.Password.$error">
     <div ng-message="required">This is required!</div>
     </div>
 </md-input-container>                             

 <md-input-container>
    <md-button id="registerUser" value="Register" class="md-raised md-primary" ng-click="userForm.$valid &&  vm.registerUser()" aria-label="login" ng-disabled="login.loginForm.$invalid()">
      Create
     </md-button>
</md-input-container>
 </form>

1 回答

  • 16

    你错过了两件事 .

    First:type="submit" 添加到您的 md-button 元素 .

    Second:novalidate 添加到您的 form 元素:

    请注意,novalidate用于禁用浏览器的本机表单验证 .

    您还应该考虑在 form 元素上使用 ng-submit 而不是在按钮上使用 ng-click .

    <form name="userForm" novalidate ng-submit="userForm.$valid &&  vm.registerUser()">
        <md-input-container>
            <input name="email" placeholder="Email" data-ng-model="vm.registerUserData.email" required />
            <div ng-messages="userForm.email.$error" ng-if='userForm.myControl.$dirty'>
                <div ng-message="required">This is required!</div>
            </div>
        </md-input-container>
    
        <md-input-container>
            <input name="Password" placeholder="Password" data-ng-model="vm.registerUserData.password" required />
            <div ng-messages="userForm.Password.$error">
                <div ng-message="required">This is required!</div>
            </div>
        </md-input-container>                             
    
        <md-input-container>
            <md-button type="submit" id="registerUser" value="Register" class="md-raised md-primary" aria-label="login" ng-disabled="login.loginForm.$invalid()">
                Create
            </md-button>
        </md-input-container>
    </form>
    

相关问题