Shr*_*air 5 inheritance components typescript ecmascript-6 angular
我正在尝试了解angular 4中的继承。
以下是我的AppComponent文件:
import { Component,OnInit } from '@angular/core';
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent implements OnInit{
  title = 'app';
  myArray= ["1","2","3"]; //THIS WORKS
  //myArray:any; //Declared but not initialized
  setTitle(value:any){
    this.title=value;
    console.log(this.myArray[2]);
  }
  ngOnInit(){
    //this.myArray=["1","2","3"]; //THIS DOESNT WORK
  }
}
这是扩展AppComponent的另一个组件
import { Component, blurbs } from '@angular/core';
import { AppComponent } from '../app.component';
@Component({
  selector: 'app-child',
  templateUrl: `<p>
  title {{title}}
  <button (click)="setTitle('child')">change title</button>
</p>`,
  styleUrls: ['./child.component.css']
})
export class ChildComponent extends AppComponent implements OnInit {
  constructor() {
    super();
   }
  ngOnInit() {
  }
}
在上面的代码中,我从ChildComponent 调用setTitle()方法。
我有一个myArray [2]的控制台日志。
如果我在声明时初始化值,则该值工作正常。
但是,如果我只是在ngOnInit块中声明并初始化数组,则console.log 无法正常工作,并告诉我myArray [2]未定义。
我的应用程序中有一个类似的场景,有人可以指导我什么是正确的方法,以及当我在ngOnInit块中初始化数组时为什么它不起作用
ngOnInit方法在中重新定义ChildComponent,此行
   //this.myArray=["1","2","3"]; //THIS DOESNT WORK
永远不会执行。
如果ChildComponent应该ngOnInit从父类继承方法,则不应定义自己的方法。如果应该扩展它,则应调用parent的方法:
  ngOnInit() {
    super.ngOnInit();
    ...
  }
| 归档时间: | 
 | 
| 查看次数: | 1268 次 | 
| 最近记录: |