使用angular自帶的表單驗證時,頁面加載的時候就顯示出來了,用戶體驗不太好,咱們的需求是,只有當輸入框失去了焦點的時候才顯示提示內容javascript
解決辦法:利用了angularjs表單驗證的錯誤對象 myForm.input.$error,給這個對象添加一個判斷當前輸入框是否失去焦點的屬性 myForm.input.$error.blur。而後利用input的事件ng-focus,ng-blur來動態改變這個值。html
注意:由於一開始 myForm.input.$error.blur 沒有給定初始值,因此確定是falsejava
<html> <head> <title></title> <--引用本身的js--> <script src="js/angular.min.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> angular.module('app', []) </script> </head> <body ng-app="app"> <form name="myForm" > <div class=""> 用戶名 <input name="input" ng-model="userType" ng-blur="myForm.input.$error.focus=false" ng-focus="myForm.input.$error.focus=true" required> <span ng-show="myForm.input.$error.required && !myForm.input.$error.focus">必填項</span><br> </div> <div class=""> 密碼: <input name="psd" ng-model="psd" ng-blur="myForm.psd.$error.blur=true" ng-focus="myForm.psd.$error.blur=false" required> <span ng-show="myForm.psd.$error.required &&myForm.psd.$error.blur">必填項</span><br> </div> </form> </body> </html>