Register a new directive with the compiler.
Param | Type | Details |
---|---|---|
name | string Object | Name of the directive in camel-case (i.e. |
directiveFactory | function() Array | An injectable directive factory function. See the directive guide and the compile API for more info. |
ng.$compileProvider |
Self for chaining. |
Register a component definition with the compiler. This is a shorthand for registering a special type of directive, which represents a self-contained UI component in your application. Such components are always isolated (i.e. scope: {}
) and are always restricted to elements (i.e. restrict: 'E'
).
Component definitions are very simple and do not require as much configuration as defining general directives. Component definitions usually consist only of a template and a controller backing it.
In order to make the definition easier, components enforce best practices like use of controllerAs
, bindToController
. They always have isolate scope and are restricted to elements.
Here are a few examples of how you would usually define components:
var myMod = angular.module(...); myMod.component('myComp', { template: '<div>My name is {{$ctrl.name}}</div>', controller: function() { this.name = 'shahar'; } }); myMod.component('myComp', { template: '<div>My name is {{$ctrl.name}}</div>', bindings: {name: '@'} }); myMod.component('myComp', { templateUrl: 'views/my-comp.html', controller: 'MyCtrl', controllerAs: 'ctrl', bindings: {name: '@'} });
For more examples, and an in-depth guide, see the component guide.
See also $compileProvider.directive().
Param | Type | Details |
---|---|---|
name | string | Name of the component in camelCase (i.e. |
options | Object | Component definition object (a simplified directive definition object), with the following properties (all optional):
|
ng.$compileProvider |
the compile provider itself, for chaining of function calls. |
Retrieves or overrides the default regular expression that is used for whitelisting of safe urls during a[href] sanitization.
The sanitization is a security measure aimed at preventing XSS attacks via html links.
Any url about to be assigned to a[href] via data-binding is first normalized and turned into an absolute url. Afterwards, the url is matched against the aHrefSanitizationWhitelist
regular expression. If a match is found, the original url is written into the dom. Otherwise, the absolute url is prefixed with 'unsafe:'
string and only then is it written into the DOM.
Param | Type | Details |
---|---|---|
regexp (optional) | RegExp | New regexp to whitelist urls with. |
RegExp ng.$compileProvider
|
Current RegExp if called without value or self for chaining otherwise. |
Retrieves or overrides the default regular expression that is used for whitelisting of safe urls during img[src] sanitization.
The sanitization is a security measure aimed at prevent XSS attacks via html links.
Any url about to be assigned to img[src] via data-binding is first normalized and turned into an absolute url. Afterwards, the url is matched against the imgSrcSanitizationWhitelist
regular expression. If a match is found, the original url is written into the dom. Otherwise, the absolute url is prefixed with 'unsafe:'
string and only then is it written into the DOM.
Param | Type | Details |
---|---|---|
regexp (optional) | RegExp | New regexp to whitelist urls with. |
RegExp ng.$compileProvider
|
Current RegExp if called without value or self for chaining otherwise. |
Call this method to enable/disable various debug runtime information in the compiler such as adding binding information and a reference to the current scope on to DOM elements. If enabled, the compiler will add the following to DOM elements that have been bound to the scope
ng-binding
CSS class$binding
data property containing an array of the binding expressionsYou may want to disable this in production for a significant performance boost. See Disabling Debug Data for more.
The default value is true.
Param | Type | Details |
---|---|---|
enabled (optional) | boolean | update the debugInfoEnabled state if provided, otherwise just return the current debugInfoEnabled state |
* |
current value if used as getter or itself (chaining) if used as setter |
Call this method to enable/disable whether directive controllers are assigned bindings before calling the controller's constructor. If enabled (true), the compiler assigns the value of each of the bindings to the properties of the controller object before the constructor of this object is called.
If disabled (false), the compiler calls the constructor first before assigning bindings.
The default value is true in Angular 1.5.x but will switch to false in Angular 1.6.x.
Param | Type | Details |
---|---|---|
enabled (optional) | boolean | update the preAssignBindingsEnabled state if provided, otherwise just return the current preAssignBindingsEnabled state |
* |
current value if used as getter or itself (chaining) if used as setter |
Sets the number of times $onChanges
hooks can trigger new changes before giving up and assuming that the model is unstable.
The current default is 10 iterations.
In complex applications it's possible that dependencies between $onChanges
hooks and bindings will result in several iterations of calls to these hooks. However if an application needs more than the default 10 iterations to stabilize then you should investigate what is causing the model to continuously change during the $onChanges
hook execution.
Increasing the TTL could have performance implications, so you should not change it without proper justification.
Param | Type | Details |
---|---|---|
limit | number | The number of |
number object
|
the current limit (or |
It indicates to the compiler whether or not directives on comments should be compiled. Defaults to true
.
Calling this function with false disables the compilation of directives on comments for the whole application. This results in a compilation performance gain, as the compiler doesn't have to check comments when looking for directives. This should however only be used if you are sure that no comment directives are used in the application (including any 3rd party directives).
Param | Type | Details |
---|---|---|
enabled | boolean |
|
boolean object
|
the current value (or |
It indicates to the compiler whether or not directives on element classes should be compiled. Defaults to true
.
Calling this function with false disables the compilation of directives on element classes for the whole application. This results in a compilation performance gain, as the compiler doesn't have to check element classes when looking for directives. This should however only be used if you are sure that no class directives are used in the application (including any 3rd party directives).
Param | Type | Details |
---|---|---|
enabled | boolean |
|
boolean object
|
the current value (or |
© 2010–2017 Google, Inc.
Licensed under the Creative Commons Attribution License 4.0.
https://code.angularjs.org/1.5.11/docs/api/ng/provider/$compileProvider