[Angular2 @ RC4] [angularfire2 @ 2.0.0-beta.2]
在我的子组件中,我无法changes['posX'].previousValue
存储任何东西。
来自父 html 的片段:
//inside *ngfor loop
[posX]='coord.position_x | calculateX:395'
[posY]='coord.position_y | calculateY:380'
来自子组件的片段:
export class childComponent implements OnChanges {
@Input() posX: number; //updated via firebase database from parant
@Input() posY: number; //updated via firebase database from parant
ngOnChanges(changes: {[ propName: string]: SimpleChange}) {
console.log('Change detected: ', changes['posX'].currentValue);
console.log('Change detected: ', changes['posX'].previousValue);
}
来自 chrome 控制台的结果:
Change detected: posX current = 343 //changes every time
Change detected: posX previous = Object {} //same after updates
我找到了 ngOnChange 的这个plnkr,并且能够让它在我的应用程序中运行。虽然我无法让 PosX 和 PosY 变量以相同的方式工作。
变量 PosX 和 PosY 每 15 秒通过我的 firebase 数据库中的 observable 更新一次。知道为什么 previousValue 没有出现吗?