繁体   English   中英

使用Angular动态添加HTML属性

[英]Adding HTML attributes dynamically with Angular

我正在尝试将HTML属性添加到表单字段以在JSON文件中的属性为true时禁用它。

在我的表单字段中,我添加了data-is-disabled={{field.rules.disabled}} ,该数据从JSON中的以下内容读取

"rules" : {
    "disabled": "true"
}

然后,在我的模块中有一条指令,我想要删除该属性并将其替换为disabled属性以禁用该字段。

app.directive ('isDisabled', function($compile) {
    return {
        restrict: 'A',
        compile: function (element) {
            element.removeAttr("data-is-disabled");
            element.attr("disabled");
            var fn = $compile(element);
            return function(scope){
                fn(scope);
            };
        }
    }
});

它看起来过于复杂,但是对于多种不同的字段类型情况则是必需的,在这种情况下,必须禁用该字段。

我从SO那里尝试了几种不同的解决方案,但是我还没有开始工作。 该属性保留为data-is-disabled="true"

提前谢谢了。

使它更简单并使用它。

https://docs.angularjs.org/api/ng/directive/ngDisabled

ng-disabled={{field.rules.disabled}}

请注意并检查您的数据,因为true是字符串,而是执行...

ng-disabled={{JSON.parse(field.rules.disabled)}}

使用此链接属性:

directive ('isDisabled', function() {
    return {
        restrict: 'A',
        scope : {
          isDisabled : "="
        },
        link : function(scope, ele, attr){
          if(scope.isDisabled){
            ele.attr("disabled", true);
          }
        }
}

看到链接: https : //plnkr.co/edit/01JnAyDEce2p43aHlL83?p=preview

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM