我已经附上了我的angular2代码片段的plunker.我想从我的JSON打印一个字段,但无法打印,因为最初我的对象为空,并且它是通过promise 填充的.
这是我的组件文件
import {Component, NgModule, OnInit} from '@angular/core'
import {BrowserModule} from '@angular/platform-browser'
class MyData {
xyz : MySubData;
}
class MySubData {
name : string;
}
@Component({
selector: 'my-app',
template: `
<div>
<h2>Hello {{name}}</h2>
{{abc.xyz.name}}
</div>
`,
})
export class App implements OnInit {
abc : MyData = null;
constructor() {
this.name = 'Angular2'
}
ngOnInit() {
setTimeout(() => {
this.abc = new MyData();
this.abc.xyz = new MySubData();
this.abc.xyz.name = "Binita";
}, 2000);
}
}
@NgModule({
imports: [ BrowserModule ],
declarations: [ App ],
bootstrap: [ App ]
})
export class AppModule {}
当我从模板中删除行{{abc.xyz.name}}
时,它运行良好.
我在代码中使用了设置时间,因为我从Promise(即异步调用)获取数据.
我一开始能理解,因为abc
是null
,我的代码找不到abc.xyz.名称但我不想判断任何if条件.因为我在JSON中有几个属性,每个属性都不可能写入if条件.
在angularjs 1的前面部分,如果abc为空,那么它将自动用空字符串替换它.我想在angular2做同样的事情.请建议.
下面是plunker