没有要求输入变更的指令

时间:2016-04-01 08:41:27

标签: javascript angularjs angularjs-directive

我正面临着一个我似乎无法解决的问题。 我有几个输入,每个指令用于验证输入值,如下所示:

<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/

我希望有人能指出我正确的方向。 提前谢谢。

1 个答案:

答案 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