updated_at: 2024-12-15 04:07

extends

extends는 버젼에 따라 사용법이 약간 다르다. 최신버전의 angular에서 중간의 이전버젼 사용시 Class is using Angular features but is not decorated. Please add an explicit Angular decorator 에러가 발생한다.

Angular 10 이상에서의 사용법

  • parent.ts
import { Component, Injector } from '@angular/core';
@Component({  // 아래와 같이 빈  template를 넣어 주어야 한다.
  template: ''
})
export abstract class ParentComponent { // abstract 추가하면 이전 버젼처럼 사용가능하다.
    constructor(
        protected injector: Injector,
    ) {
        this.authSvc = this.injector.get(AuthService);
        .....
    }
}
  • child.ts
import { Injector } from '@angular/core';
export class ChildComponent extends ParentComponent {

    constructor(
        protected injector: Injector,
    ){
        super(injector);
    }

이전 사용법

extens 는 상속을 받을 때 사용한다. 여러 components 에서 중복으로 사용하는 소스코드가 많을 경우 매우 유용하다.

  • parent.ts
import { Injector } from '@angular/core';
export class ParentComponent {
    constructor(
        protected injector: Injector,
    ) {
        this.authSvc = this.injector.get(AuthService);
        .....
    }
}
  • child.ts
import { Injector } from '@angular/core';
export class ChildComponent extends ParentComponent {

    constructor(
        protected injector: Injector,
    ){
        super(injector);
    }

override keyword : 부모에서 사용하는 메소드와 동일한 이름을 child 에서 사용하여 속성을 바꿀때..

protected : 무모에서 메소스 정의시 자식에서 사용하고 public 이 아닐 경우

  • 자식에서는 this 를 이용하여 부모의 method 에 접근하지만 부모에서는 자식의 값에 접근을 할 수 없다. 이경우 rxjs등을 이용하여 사용할 수도 있지만 callback 을 이용하여 부모에서 자식을 호출하는 방식도 괜찮다.
  • parent.ts
protected receiveCallback: any = false;

export class ParentComponent {
    public receiveMethod() {
        // somedata receved from api ...
        if (this.receiveCallback) {
            this.receiveCallback(res);
        }
    }
}
  • child.ts
export class ChildComponent extends ParentComponent {

    constructor(
        protected injector: Injector,
    ){
        super(injector);

        this.receiveCallback = (res: any) => { this.receiveResult(res); }
    }

    private receiveResult(res) {
        console.log(res);
    }

평점을 남겨주세요
평점 : 2.5
총 투표수 : 1

질문 및 답글