commonModule.directive("usernameVerify",[ 'userSvc',function(userSvc) { return { require: 'ngModel',scope: false,link: function(scope,element,attrs,ctrl) { ctrl.$parsers.unshift(checkForAvailability); ctrl.$formatters.unshift(checkForAvailability); function checkForAvailability(value) { if (value.length < 5) { return value; } // the userSvc.userExists function is just a call to a rest api using $http userSvc.userExists(value) .success(function(alreadyUsed) { var valid = alreadyUsed === 'false'; if (valid) { ctrl.$setValidity('usernameVerify',true); return value; } ctrl.$setValidity('usernameVerify',false); return undefined; }); } } } } ]);
这是我的模板:
<div class="form-group" ng-class="{'has-error': accountForm.username.$dirty && accountForm.username.$invalid}"> <label class=" col-md-3 control-label">Username:</label> <div class="col-md-9"> <input name="username" type="text" class="form-control" ng-model="user.username" ng-disabled="user.id" ng-minlength=5 username-verify required /> <span class="field-validation-error" ng-show="accountForm.username.$dirty && accountForm.username.$error.required">Username is required.</span> <span class="field-validation-error" ng-show="accountForm.username.$dirty && accountForm.username.$error.minlength">Username must be at least 5 characters.</span> <span class="field-validation-error" ng-show="accountForm.username.$dirty && accountForm.username.$error.usernameVerify">Username already taken.</span> </div> </div>