2016-09-25 76 views
1

我是Angular2和Typescript的新手。我試圖從我的類的構造函數獲取@Input。一個服務在構造函數中被調用,我需要傳遞一個參數。Angular2訪問@Input從構造函數中調用服務的類

@Component({ 
    selector:'side-menu', 
    templateUrl:'menu.html', 
    providers: [MenuService] 
}) 

export class SideMenuComponent { 
    @Input() blockType; 

    menuItems 

    constructor(menuService:MenuService){ 
     this.menuItems = menuService.getMenuItems(this.blockType); // Sends Undefined 
     this.menuItems = menuService.getMenuItems('HardCodedString'); //This works 
    } 


} 

,這是我的服務

@Injectable() 

export class MenuService { 
    getMenuItems(type) { 
     console.log(type) 

     switch(type){ 
      case 'Thing': 

       return []; 
       break; 
      case 'Otherthing': 
       return []; 
       break; 
      default: 
       return []; 


     } 

    } 
} 

我如何能保證@input被髮送到服務?

+0

您使用的是Angular2的哪個版本? – micronyks

回答

2

當構造函數被調用時,輸入尚未設置。改爲將構造函數代碼移動到ngOnInit()

@Component({ 
    selector:'side-menu', 
    templateUrl:'menu.html', 
    providers: [MenuService] 
}) 

export class SideMenuComponent { 
    @Input() blockType; 

    menuItems 

    constructor(private menuService:MenuService){} 

    ngOnInit() { 
     this.menuItems = this.menuService.getMenuItems(this.blockType); // Sends Undefined 
     this.menuItems = this.menuService.getMenuItems('HardCodedString'); //This works 
    } 
} 

每次@Input() s的更新ngOnChanges()被調用。
ngOnInit()ngOnChanges()之後被稱爲第一次。

+0

嘗試了這一點,並得到:core.umd.js:3464 ORIGINAL EXCEPTION:menuService沒有定義 – Rob

+0

聽起來像你缺少一個'MenuService'的導入(例如從'。/ menu.service''導入{MenuService}) –

+0

@yurzui編輯了我的答案,並修復了我從您的問題中複製的其他一些問題 - 謝謝! –

相關問題