更改属性时重建/重新渲染Angular2组件

时间:2016-05-12 07:25:39

标签: properties angular components

如何征集这个?

我的子组件

 import {Component,Input,ngOnInit} from 'angular2/core';

@Component({
selector: 'my-component',
template: `
    <div>In child component - myAttr = {{ myAttr1 }}</div>
`
})
export class MyComponent  {
  @Input() myAttr: number;
  myAttr1:number;
 ngOnInit()
 {
  this.myAttr1=this.myAttr*10;
 }

}

主要组件

import {Component} from 'angular2/core';
import {MyComponent} from './sub.component';

@Component({
selector: 'my-app',
template: `
    <my-component
        [(myAttr)]="myAttr"
    ></my-component>
    <button (click)="onClick()">Click</button>
`,
directives: [MyComponent]
})
export class AppComponent {
   myAttr: number = 1;

  onClick() {
    console.log('Click in the parent component');
    this.myAttr += 1;
  }
}

我需要更新每次点击的值。应该有一个直接的方法,否则Angular2团队应该考虑这个

1 个答案:

答案 0 :(得分:2)

您应该使用ngOnChanges来检测子组件中何时更新myAttr

@Component({
  selector: 'my-component',
  template: `
    <div>In child component - myAttr = {{ myAttr1 }}</div>
  `
})
export class MyComponent  {
  @Input() myAttr: number;
  myAttr1:number;
  ngOnInit() {
    this.myAttr1=this.myAttr*10;
  }

  ngOnChanges() { // <------
    this.myAttr1=this.myAttr*10;
  }
}

这样可以检测myAttr输入属性何时更新,并相应地更新myAttr1个属。

请参阅此plunkr:https://plnkr.co/edit/2SOdq7w3s8iDxBKbiLpU?p=preview