Ran*_*dan 8 typescript ionic2 ionic3 angular
我正在使用Ionic 2,其中一个组件有两个组件,数据是使用发射器共享的.但是当我执行程序时,就出现了这个错误.
运行时错误未捕获(在promise中):TypeError:无法读取未定义的TypeError错误属性'BillNo':无法读取Object.eval中未定义的属性'BillNo'[as updateDirectives]
这是我的代码:
比尔 - settlement.html
...
<page-bill-list (BillSelected)="onBillSelected($event)"></page-bill-list>
...
<page-bill-details [billItem]="billItem"></page-bill-details>
...
Run Code Online (Sandbox Code Playgroud)
比尔 - settlement.ts
@Component({
selector: 'page-bill-settlement',
templateUrl: 'bill-settlement.html',
})
export class BillSettlement {
...
billItem: BillDetail
...
onBillSelected(billData: BillDetail) {
this.billItem = billData
}
}
Run Code Online (Sandbox Code Playgroud)
比尔 - list.html
<ion-buttons>
<button ion-button *ngFor="let item of billItems" (click)="getBillDetails(item)">
{{item.BillNo}}
</button>
</ion-buttons>
Run Code Online (Sandbox Code Playgroud)
比尔 - list.ts
@Component({
selector: 'page-bill-list',
templateUrl: 'bill-list.html',
})
export class BillList {
billItems: BillDetail[] = []
billItem = new BillDetail()
@Output() BillSelected = new EventEmitter<BillDetail>()
constructor(public navCtrl: NavController,
public navParams: NavParams,
public billSrv: BillerService,
public authSrv: AuthService,
public genSrv: GenericService) {
this.billSrv.getBills()
.subscribe(data => {
this.billItems = data
})
}
getBillDetails(item: BillDetail) {
this.BillSelected.emit(this.billItem)
}
}
Run Code Online (Sandbox Code Playgroud)
比尔 - details.ts
@Component({
selector: 'page-bill-details',
templateUrl: 'bill-details.html',
})
export class BillDetails {
...
@Input() billItem: BillDetail
...
}
Run Code Online (Sandbox Code Playgroud)
比尔 - details.html
...
<ion-input text-right type="text" [value]="billItem.BillNo" readonly></ion-input> //billItem model has BillNo property
...
Run Code Online (Sandbox Code Playgroud)
问题是,billItem.BillNo在bill-details.ts最初没有价值,只有当我点击该法案号按钮,它被定义bill-list.html.如何最初定义billItem,然后在使用bill number按钮单击时替换.
Sur*_*Rao 20
视图在billItem设置之前加载.
您可以使用安全的导航操作员?.
<ion-input text-right type="text" [value]="billItem?.BillNo" readonly></ion-input> //billItem model has BillNo property
Run Code Online (Sandbox Code Playgroud)
或者在bill-details.ts的构造函数中将其设置为空对象:
constructor(...){
if(! this.billItem){
this.billItem={}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
16873 次 |
| 最近记录: |