## Inheritance Semantics:
Decorators:
1) list the decorators of the class and its parents in the ancestor first order
2) only use the last decorator of each kind (e.g. @Component / ...)
Constructor parameters:
If a class inherits from a parent class and does not declare
a constructor, it inherits the parent class constructor,
and with it the parameter metadata of that parent class.
Lifecycle hooks:
Follow the normal class inheritance model,
i.e. lifecycle hooks of parent classes will be called
even if the method is not overwritten in the child class.
## Example
E.g. the following is a valid use of inheritance and it will
also inherit all metadata:
```
@Directive({selector: 'someDir'})
class ParentDirective {
  constructor(someDep: SomeDep) {}
  ngOnInit() {}
}
class ChildDirective extends ParentDirective {}
```
Closes #11606
Closes #12892
		
	
			
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | |
|  * @license
 | |
|  * Copyright Google Inc. All Rights Reserved.
 | |
|  *
 | |
|  * Use of this source code is governed by an MIT-style license that can be
 | |
|  * found in the LICENSE file at https://angular.io/license
 | |
|  */
 | |
| 
 | |
| import {PipeResolver} from '@angular/compiler/src/pipe_resolver';
 | |
| import {Pipe} from '@angular/core/src/metadata';
 | |
| import {stringify} from '../src/facade/lang';
 | |
| 
 | |
| @Pipe({name: 'somePipe', pure: true})
 | |
| class SomePipe {
 | |
| }
 | |
| 
 | |
| class SimpleClass {}
 | |
| 
 | |
| export function main() {
 | |
|   describe('PipeResolver', () => {
 | |
|     let resolver: PipeResolver;
 | |
| 
 | |
|     beforeEach(() => { resolver = new PipeResolver(); });
 | |
| 
 | |
|     it('should read out the metadata from the class', () => {
 | |
|       const moduleMetadata = resolver.resolve(SomePipe);
 | |
|       expect(moduleMetadata).toEqual(new Pipe({name: 'somePipe', pure: true}));
 | |
|     });
 | |
| 
 | |
|     it('should throw when simple class has no pipe decorator', () => {
 | |
|       expect(() => resolver.resolve(SimpleClass))
 | |
|           .toThrowError(`No Pipe decorator found on ${stringify(SimpleClass)}`);
 | |
|     });
 | |
| 
 | |
|     it('should support inheriting the metadata', function() {
 | |
|       @Pipe({name: 'p'})
 | |
|       class Parent {
 | |
|       }
 | |
| 
 | |
|       class ChildNoDecorator extends Parent {}
 | |
| 
 | |
|       @Pipe({name: 'c'})
 | |
|       class ChildWithDecorator extends Parent {
 | |
|       }
 | |
| 
 | |
|       expect(resolver.resolve(ChildNoDecorator)).toEqual(new Pipe({name: 'p'}));
 | |
| 
 | |
|       expect(resolver.resolve(ChildWithDecorator)).toEqual(new Pipe({name: 'c'}));
 | |
|     });
 | |
| 
 | |
|   });
 | |
| }
 |