データベース内の値の一意性をチェックするためのディレクティブ「ensureUniqueValidator」があります。関数は汎用的です。これは、HTML ページで次のように呼び出されます。
<input type="email" name="email" ng-model="userCtrl.user.email"
required ensure-unique-validator />
指令コード:
app.directive('ensureUniqueValidator', [
'$http',
function($http) {
return {
restrict : 'A',
require : 'ngModel',
link : function(scope, ele, attrs, c) {
c.$parsers.push(function(val) {
return $http.get(
'MainServlet.do?method=is' + attrs.name
+ 'unique&' + attrs.name + '='
+ val).then(
function(result) {
console.log(result.data);
c.$setValidity('ensureUniqueValidator',
result.data);
return result.data;//returns true or false
});
});
}
}
} ]);
問題は、サーバーが False を返した場合でもフォームが有効なままであることです。$setValidity 関数はフォームを無効にしていないようです。
ここで何か間違ったことをしていますか?前もって感謝します。