我正面临着一个我似乎无法解决的问题。 我有几个输入,每个指令用于验证输入值,如下所示:
<div class="row form-group">
<div class="col-sm-6">last name</div>
<div class="col-sm-6">
<div class="input-group" ng-class="{'has-error': form.lastname.$invalid && (form.lastname.$touched || form.$submitted)}">
<input type="text" name="lastname" class="form-control"
model-blur
validator-lastname
ng-trim="true"
ng-model="fields.lastname.value"
ng-maxlength="fields.lastname.validation.maxLength">
<input-group-addon class="input-group-addon"
iga-char=""
iga-form="form"
iga-field="form.lastname"
iga-if-touched="true">
</input-group-addon>
</div>
<form-message-list fml-form="form"
fml-field="form.lastname"
fml-label="Last name"
fml-fieldData="fields.lastname">
</form-message-list>
</div>
</div>
此字段需要以下模式:/^[\'a-zA-Z_]+( [\'a-zA-Z_]+)*$/
我的问题是: 当我在输入中添加无效值时,如下所示:/,我的无效邮件仍然存在且ng-invalid-pattern保留在我的字段中。
当我将此模式添加到我的字段时:ng-pattern="/^[\'a-zA-Z_]+( [\'a-zA-Z_]+)*$/"
我没有任何问题。但是当我尝试通过我的指令 validator-lastname 进行验证时,它只会检查一次。当我用无效值填充输入然后将其更改为空(允许)时,ng-invalid-pattern错误仍然存在。
这是我的指示:
angular.module('app')
.directive('validatorLastname', validatorLastname);
/* @ngInject */
function validatorLastname() {
var directive = {
require: 'ngModel',
link: link
};
return directive;
function link(scope, element, attrs, modelCtrl) {
var valid = false;
var formatter = function (inputValue) {
if (inputValue) {
var res = inputValue.match(/^[\'a-zA-Z_]+( [\'a-zA-Z_]+)*$/);
if (res && res.length > 0) {
valid = true;
}
modelCtrl.$setValidity('pattern', valid);
valid = false;
}
return inputValue;
};
modelCtrl.$parsers.push(formatter);
if (scope[attrs.ngModel] && scope[attrs.ngModel] !== '') {
formatter(scope[attrs.ngModel]);
}
}
}
我制作了一个JSFiddle来重现问题:http://jsfiddle.net/sZZEt/537/
我希望有人能指出我正确的方向。 提前谢谢。
答案 0 :(得分:3)
您应该更新指令代码,以使一切正常。
angular.module('app')
.directive('validatorLastname', validatorLastname);
/* @ngInject */
function validatorLastname() {
var directive = {
require: 'ngModel',
link: link
};
return directive;
function link(scope, element, attrs, modelCtrl) {
var valid = false;
var formatter = function (inputValue) {
if (inputValue) {
var res = inputValue.match(/^[\'a-zA-Z_]+( [\'a-zA-Z_]+)*$/);
if (res && res.length > 0) {
valid = true;
}
modelCtrl.$setValidity('pattern', valid);
valid = false;
}else{
modelCtrl.$setValidity('pattern', true);
}
return inputValue;
};
modelCtrl.$parsers.push(formatter);
if (scope[attrs.ngModel] && scope[attrs.ngModel] !== '') {
formatter(scope[attrs.ngModel]);
}
}
}
我为您的问题创建了plunk
...
这是因为如果inputValue为null,那么$ setValidity方法将不会调用,也无法再次执行验证。您应该在其他部分内将模式有效性设置为true。如果你想使字段对无输入有效。
您现在可以参考更新的plunk https://plnkr.co/edit/N3DrsB?p=preview