我创建了一个优先级为1000的自定义指令.在指令的编译函数中,我从元素中删除了ng-if.我的假设是,由于ng-if的优先级较低,因此不应编译.
app.js
var app = angular.module('plunker', []);
app.controller('MainCtrl', function($scope) {
});
app.directive('myDirective', function(){
return {
priority: 1000,
compile: function(element){
angular.element(element).removeAttr('ng-if').removeAttr('my-directive1');
}
};
});
app.directive('myDirective1', function(){
return {
compile: function(){
console.log('in mydirective1');
}
};
});
的index.html
<div my-directive ng-if="false" my-directive1>
This div should be visible.
</div>
我创建了另一个指令来检查我对优先级的理解是否正确. myDirective成功删除myDirective1,但不是ngIf.
以下是plunker链接:
https://plnkr.co/edit/86mauwbt5I2aV4aoySpz?p=preview
解决方法:
我不确定为什么优先级不会这样.我建议使用终端来消除低优先级指令.这是更新Plunker.
app.directive('myDirective', function(){
return {
priority: 1000,
terminal: true,
compile: function(element){
//element.removeAttr('ng-if').removeAttr('my-directive1');
}
};
});
另请参阅有关终端的这些问题:
> How to understand the `terminal` of directive?
> Why use terminal: true instead of removing lower priority directives?