0

我正在使用最新版本的 AngularJS 1.2rc3 以及 Bootstrap 进行样式设置,并具有如下指令:

angular.module('form.field', [])

.directive('efield', function() {
    return {
        restrict: 'E',
        scope: {
            form: '@',
            fname: '@',
            label: '@'
        },
        template:   "<div data-ng-class=\"{{form}}.{{fname}}.$valid ? 'form-group' : 'form-group has-error'\">" +
                        "<label class='control-label' for='{{fname}}'>{{label}}</label>" +
                        "<input type='text' class='form-control' name='{{fname}}' data-ng-required='false' data-ng-model='Form.test'>" +
                    "</div>"

    }
});

html 片段如下所示:

<form name="form" novalidate="novalidate">
    <efield form="form" fname="test" label="field"></efield>
</form>

我正在使用指令来包装字段 html 和 angular 的验证指令以减少样板代码。问题是即使在输入字段上设置了 data-ng-required='false',父 div 也会得到“form-group has error”类,而不仅仅是“form-group”。我在这里做错了什么?

4

2 回答 2

1

由于您在指令中创建的隔离范围,您遇到了问题。有几种方法可以接近它。这是一个将删除隔离范围并template:function(elem,attrs)改为使用的方法

.directive('efield', function () {
    return {
        restrict: 'E',

        template: function (elem, attrs) {

            return "<div data-ng-class=\"" + attrs.form + "." + attrs.fname + ".$valid ? 'form-group' : 'form-group has-error'\">" +
                "<label class='control-label' for='" + attrs.fname + "'>" + attrs.label + "</label>" +
                "<input type='text' class='form-control' name='" + attrs.fname + "' data-ng-required='false' data-ng-model='Form.test'>" +
                "</div>"

        }
    });

现在范围将是父范围的范围

于 2013-10-30T15:00:16.643 回答
0

看看这个指令https://github.com/nelsonomuto/angular-ui-form-validation

于 2014-06-11T15:39:30.650 回答