2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Directives
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directives are classes which get instantiated as a response to a particular DOM structure. By controlling the DOM structure, what directives are imported, and their selectors, the developer can use the [composition pattern ](http://en.wikipedia.org/wiki/Object_composition ) to get a desirable application behavior.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directives are the cornerstone of an Angular application. We use Directives to break complex problems into smaller more reusable components. Directives allow the developer to turn HTML into a DSL and then control the application assembly process.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Angular applications do not have a main method. Instead they have a root Component. Dependency Injection then assembles the directives into a working Angular application.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directives with an encapsulated view and an optional injector are called *Components* .
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## CSS Selectors
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directives are instantiated whenever the CSS selector matches the DOM structure.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Angular supports these CSS selector constructs:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Element name: `name`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Attribute: `[attribute]`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Attribute has value: `[attribute=value]`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Attribute contains value: `[attribute*=value]`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Class: `.class`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  AND operation: `name[attribute]`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  OR operation: `name,.class`  
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  NOT operation: `:not(.class)`  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Angular does not support these (and any CSS selector which crosses element boundaries):
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Descendant: `body div`  
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Direct descendant: `body > div`  
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Adjacent: `div + table`  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Sibling: `div ~ table`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Wildcard: `*`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  ID: `#id`  
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Pseudo selectors: `:pseudo`  other than `:not`  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Given this DOM:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```<input type="text" required class="primary">` ``
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								These CSS selectors will match:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `input` : Triggers whenever element name is `input` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `[required]` : Triggers whenever element contains a required attribute. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `[type=text]` : Triggers whenever element contains attribute `type`  whose value is `text` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `.primary` : Triggers whenever element class contains `primary` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								CSS Selectors can be combined:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `input[type=text]` : Triggers on element name `input`  which is of `type`  `text` . 
						 
					
						
							
								
									
										
										
										
											2015-04-14 19:29:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `input[type=text], textarea` : triggers on element name `input`  which is of `type`  `text`  or element name `textarea` . 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Directives
  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The simplest kind of directive is a decorator. Directives are usefull for encapsulating behavior.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Multiple decorators can be placed on a single element. 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Directives do not introduce new evaluation context. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Directives are registered through the `@Directive`  meta-data annotation. 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Here is a trivial example of a tooltip decorator. The directive will log a tooltip into the console on every time mouse enters a region:
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ 
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  selector: '[tooltip]',     | CSS Selector which triggers the decorator
							 
						 
					
						
							
								
									
										
										
										
											2015-05-26 15:54:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  properties: [              | List which properties need to be bound
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'text: tooltip'          |  - DOM element tooltip property should be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ],                         |    mapped to the directive text property.
							 
						 
					
						
							
								
									
										
										
										
											2015-06-09 12:46:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  host: {                    | List which events need to be mapped.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    (mouseover): 'show()'    |  - Invoke the show() method every time
							 
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  }                          |    the mouseover event is fired.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})                           |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Form {                 | Directive controller class, instantiated
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                             | when CSS matches.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  text:string;               | text property on the Directive Controller.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                             |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  show(event) {              | Show method which implements the show action.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    console.log(this.text);  |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example of usage:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```<span tooltip="Tooltip text goes here.">Some text here.</span>` ``
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The developer of an application can now freely use the `tooltip`  attribute wherever the behavior is needed. The code above has taught the browser a new reusable and declarative behavior.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Notice that data binding will work with this decorator with no further effort as shown below.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```<span tooltip="Greetings {{user}}!">Some text here.</span>` ``
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Components
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-15 19:57:09 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Component is a directive which uses shadow DOM to create encapsulate visual behavior. Components are typically used to create UI widgets or to break up the application into smaller components.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Only one component can be present per DOM element. 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Component's CSS selectors usually trigger on element names. (Best practice) 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Component has its own shadow view which is attached to the element as a Shadow DOM. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Shadow view context is the component instance. (i.e. template expressions are evaluated against the component instance.) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>> TODO(misko): Configuring the injector
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example of a component:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@Component ({                      | Component annotation 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  selector: 'pane',               | CSS selector on < pane >  element
							 
						 
					
						
							
								
									
										
										
										
											2015-05-26 15:54:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  properties: [                   | List which property need to be bound
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'title',                      |  - title mapped to component title
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'open'                        |  - open attribute mapped to component's open property
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ],                              |
							 
						 
					
						
							
								
									
										
										
										
											2015-02-15 23:41:36 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})                                |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-09 21:20:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@View ({                           | View annotation 
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  templateUrl: 'pane.html'        |  - URL of template HTML
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								})                                |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Pane {                      | Component controller class
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  title:string;                   |  - title property
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  open:boolean;
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  constructor() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.title = '';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.open = true;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  // Public API
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  toggle() => this.open = !this.open;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  open() => this.open = true;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  close() => this.open = false;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`pane.html` : 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = "outer" >  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  < h1 > {{title}}< / h1 > 
							 
						 
					
						
							
								
									
										
										
										
											2015-03-16 23:31:06 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  < div  class = "inner"  [ hidden ] = " ! open " > 
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    < content > < / content > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / div > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`pane.css` : 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								.outer, .inner { border: 1px solid blue;}
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								.h1 {background-color: blue;}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example of usage:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-02-24 11:09:07 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< pane  #pane  title = "Example Title"  open = "true" >  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  Some text to wrap.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< / pane >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< button  ( click ) = " pane . toggle ( ) " > toggle< / button >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Directives that use a ViewContainer
  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directives that use a ViewContainer can control instantiation of child views which are then inserted into the DOM. (Examples are `ng-if`  and `ng-for` .)
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  Every `template`  element creates a `ProtoView`  which can be used to create Views via the ViewContainer. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  The child views show up as siblings of the directive in the DOM. 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>> TODO(misko): Relationship with Injection
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								>> TODO(misko): Instantiator can not be injected into child Views
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ 
						 
					
						
							
								
									
										
										
										
											2015-02-04 22:27:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  selector: '[if]',
							 
						 
					
						
							
								
									
										
										
										
											2015-05-26 15:54:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  properties: [
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    'condition: if'
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ]
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
									
										
										
										
											2015-02-04 22:27:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								export class If {
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  viewContainer: ViewContainerRef;
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  protoViewRef: ProtoViewRef;
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  view: View;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  constructor(viewContainer: ViewContainerRef, protoViewRef: ProtoViewRef) {
							 
						 
					
						
							
								
									
										
										
										
											2015-02-12 11:54:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    this.viewContainer = viewContainer;
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    this.protoViewRef = protoViewRef;
							 
						 
					
						
							
								
									
										
										
										
											2015-02-12 11:54:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    this.view = null;
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  set condition(value) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (value) {
							 
						 
					
						
							
								
									
										
										
										
											2015-02-12 11:54:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if (this.view === null) {
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        this.view = this.viewContainer.create(protoViewRef);
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } else {
							 
						 
					
						
							
								
									
										
										
										
											2015-02-12 11:54:22 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      if (this.view !== null) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        this.viewContainer.remove(this.view);
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        this.view = null;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Dependency Injection
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Dependency Injection (DI) is a key aspect of directives. DI allows directives to be assembled into different [compositional ](http://en.wikipedia.org/wiki/Object_composition ) hierarchies. Angular encourages [composition over inheritance ](http://en.wikipedia.org/wiki/Composition_over_inheritance ) in the application design (but inheritance based approaches are still supported).
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								When Angular directives are instantiated, the directive can ask for other related directives to be injected into it. By assembling the directives in different order and subtypes the application behavior can be controlled. A good mental model is that the DOM structure controls the directive instantiation graph.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Directive instantiation is triggered by the directive CSS selector matching the DOM structure. In a directive's constructor, it can ask for other directives or application services. When asking for directives, the dependency is attempted to be located by its DOM hierarchy first, then if not found, by using the application level injector.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								To better understand the kinds of injections which are supported in Angular we have broken them down into use case examples.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Injecting Services
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-05-16 15:21:36 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Service injection is the most straight forward kind of injection which Angular supports. It involves a component configuring the `appInjector`  and then letting the directive ask for the configured service.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-02-14 20:06:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This example illustrates how to inject `MyService`  into `House`  directive.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class MyService {}                   | Assume a service which needs to be injected
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                                     | into a directive.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Component ({                         | Assume a top level application component which 
						 
					
						
							
								
									
										
										
										
											2015-02-15 23:41:36 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  selector: 'my-app',                | configures the services to be injected.
							 
						 
					
						
							
								
									
										
										
										
											2015-05-16 15:21:36 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  appInjector: [MyService]           |
							 
						 
					
						
							
								
									
										
										
										
											2015-02-15 23:41:36 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})                                   |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-09 21:20:11 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@View ({                              | Assume we have a template that needs to be 
						 
					
						
							
								
									
										
										
										
											2015-05-14 17:21:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  templateUrl: 'my_app.html',        | configured with directives to be injected.
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  directives: [House]                |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								})                                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyApp {}                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({                         | This is the directive into which we would like 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  selector: '[house]'                | to inject the MyService.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})                                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class House {                        |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  constructor(myService:MyService) { | Notice that in the constructor we can simply
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  }                                  | ask for MyService.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-01-27 00:13:23 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Assume the following DOM structure for `my_app.html` :
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  house >      | The house attribute triggers the creation of the House directive. 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< / div >           | This is equivalent to: 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                |   new House(injector.get(MyService));
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Injecting other Directives
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Injecting other directives into directives follows a similar mechanism as injecting services into directives, but with added constraint of visibility governed by DOM structure.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								There are five kinds of visibilities:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  (no annotation): Inject dependant directives only if they are on the current element. 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `@ancestor` : Inject a directive if it is at any element above the current element. 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `@parent` : Inject a directive which is a direct parent of the current element. 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `@child` : Inject a list of direct children which match a given type. (Used with `Query` ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `@descendant` : Inject a list of any children which match a given type. (Used with `Query` ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								NOTE: if the injection constraint can not be satisfied by the current visibility constraint, then it is forwarded to the normal injector which either provides a default value for the directive or throws an error.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Here is an example of the kinds of injections which can be achieved:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@Component ({                         | 
						 
					
						
							
								
									
										
										
										
											2015-04-12 01:13:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  selector: 'my-app'                 |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})                                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@View ({                              | 
						 
					
						
							
								
									
										
										
										
											2015-04-12 01:13:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  templateUrl: 'my_app.html',        |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  directives: [Form, FieldSet,       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Field, Primary]                  |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								})                                   |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyApp {}                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ selector: 'form' })     | 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								class Form {                         |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor(                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @descendant  sets:Query< FieldSet >  |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  ) {                                |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }                                  |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ selector: 'fieldset' }) | 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								class FieldSet {                     |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor(                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @child  sets:Query< Field >          |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  ) { ... }                          |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ selector: 'field' })    | 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								class Field {                        |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor(                       |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @ancestor  field:Form,            |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @parent  field:FieldSet,          |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  ) { ... }                          |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                     |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-30 13:38:40 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Directive ({ selector: '[primary]'}) | 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								class Primary {                      |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  constructor(field:Field ) { ... }  |
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}                                    |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-01-27 00:13:23 -08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Assume the following DOM structure for `my_app.html` :
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								< form >                          | 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < div >                         |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    < fieldset >                  |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								       < field  primary > < / field >  |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								       < field > < / field >          |
							 
						 
					
						
							
								
									
										
										
										
											2015-03-26 19:48:17 +09:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    < / fieldset >                 |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  < / div >                        |
							 
						 
					
						
							
								
									
										
										
										
											2015-04-27 09:26:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< / form >                         | 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								#### Shadow DOM effects on Directive DI
  
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Shadow DOM provides an encapsulation for components, so as a general rule it does not allow directive injections to cross the shadow DOM boundaries. To remedy this, declaritively specify the required component as an injectable.
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@Component ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  selector: '[kid]',
							 
						 
					
						
							
								
									
										
										
										
											2015-05-16 15:21:36 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  appInjector: []
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@View ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  templateUrl: 'kid.html',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  directives: []
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Kid {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor(
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    @Parent () dad:Dad,
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    @Optional () grandpa:Grandpa
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  ) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.name = 'Billy';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.dad = dad.name;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.grandpa = grandpa.name;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Component ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  selector: '[dad]',
							 
						 
					
						
							
								
									
										
										
										
											2015-05-16 15:21:36 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  appInjector: [Grandpa]
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@View ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  templateUrl: 'dad.html',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  directives: [Kid]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Dad {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor(@Parent () dad:Grandpa) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.name = 'Joe Jr';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.dad = dad.name;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@Component ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  selector: '[grandpa]',
							 
						 
					
						
							
								
									
										
										
										
											2015-05-16 15:21:36 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  appInjector: []
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@View ({ 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  templateUrl: 'grandpa.html',
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  directives: [Dad]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								})
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Grandpa {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  constructor() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    this.name = 'Joe';
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  }
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Assume the following DOM structure for `grandpa.html` : The Dad has access to the Grandpa.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Name: {{name}}: < br >  Children: < div  dad > < / div > 
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Assume the following DOM structure for `dad.html` : Here the rendered Kid will also have access to Grandpa.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2015-04-29 15:07:55 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Name: {{name}}: < br >  Dad: {{dad}} < br >  Children: < div  kid > < / div > 
							 
						 
					
						
							
								
									
										
										
										
											2015-04-08 03:44:46 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2014-12-08 14:29:04 -08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Further Reading
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  [Composition ](http://en.wikipedia.org/wiki/Object_composition ) 
						 
					
						
							
								
									
										
										
										
											2015-02-15 19:57:09 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  [Composition over Inheritance ](http://en.wikipedia.org/wiki/Composition_over_inheritance )