This rule disallows the replace attribute in a directive definition object. The replace property of a directive definition object is deprecated since angular 1.3 (latest angular docs.
The option ignoreReplaceFalse
let you ignore directive definitions with replace set to false.
The following patterns are considered problems with default config;
/*eslint angular/no-directive-replace: 2*/
// invalid
angular.module('myModule').directive('helloWorld', function() {
return {
template: '<h2>Hello World!</h2>',
replace: true
};
}); // error: Directive definition property replace is deprecated.
// invalid
angular.module('myModule').directive('helloWorld', function() {
var directiveDefinition = {};
directiveDefinition.templateUrl = 'helloWorld.html';
directiveDefinition.replace = true;
return directiveDefinition;
}); // error: Directive definition property replace is deprecated.
The following patterns are not considered problems with default config;
/*eslint angular/no-directive-replace: 2*/
// valid
angular.module('myModule').directive('helloWorld', function() {
return {
template: '<h2>Hello World!</h2>'
};
});
The following patterns are not considered problems when configured {"ignoreReplaceFalse":true}
:
/*eslint angular/no-directive-replace: [2,{"ignoreReplaceFalse":true}]*/
// valid
angular.module('myModule').directive('helloWorld', function() {
return {
template: '<h2>Hello World!</h2>',
replace: false
};
});
The following patterns are considered problems when configured {"ignoreReplaceFalse":false}
:
/*eslint angular/no-directive-replace: [2,{"ignoreReplaceFalse":false}]*/
// invalid
angular.module('myModule').directive('helloWorld', function() {
return {
template: '<h2>Hello World!</h2>',
replace: true
};
}); // error: Directive definition property replace is deprecated.
This rule was introduced in eslint-plugin-angular 0.15.0