【问题标题】:Cannot read property of 'xxx' of undefined无法读取未定义的“xxx”的属性
【发布时间】:2017-05-08 04:54:41
【问题描述】:

我使用的是 Ionic 2,其中一个组件有两个组件,并且数据是使用发射器共享的。但是当我执行程序时,就出现了这个错误。

运行时错误未捕获(承诺):TypeError:无法读取属性 未定义类型错误的“BillNo”:无法读取属性“BillNo”的 在 Object.eval 未定义 [as updateDirectives]

这是我的代码:

bill-settlement.html

...
<page-bill-list (BillSelected)="onBillSelected($event)"></page-bill-list>
...
<page-bill-details [billItem]="billItem"></page-bill-details>
...

bill-settlement.ts

@Component({
  selector: 'page-bill-settlement',
  templateUrl: 'bill-settlement.html',
})
export class BillSettlement {
  ...
  billItem: BillDetail
  ...
  onBillSelected(billData: BillDetail) {
    this.billItem = billData
  }
}

bill-list.html

<ion-buttons>
  <button ion-button *ngFor="let item of billItems" (click)="getBillDetails(item)">
      {{item.BillNo}}
  </button>
</ion-buttons>

bill-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)
  }
}

bill-details.ts

@Component({
  selector: 'page-bill-details',
  templateUrl: 'bill-details.html',
})
export class BillDetails {
    ...
    @Input() billItem: BillDetail
    ...
}

bill-details.html

...
<ion-input text-right type="text" [value]="billItem.BillNo" readonly></ion-input> //billItem model has BillNo property
...

问题是bill-details.ts中的billItem.BillNo最初没有值,只有当我点击bill-list.html中的账单号按钮时才定义。如何最初定义 billItem,然后在单击账单编号按钮时替换。

【问题讨论】:

  • 试试这个:@Input() billItem: BillDetail = {};.
  • 我会将其标记为 typescript 而不是 javascript

标签: angular typescript ionic2 ionic3


【解决方案1】:

在设置billItem 之前加载视图。

您可以使用安全导航运算符?

<ion-input text-right type="text" [value]="billItem?.BillNo" readonly></ion-input> //billItem model has BillNo property

或者在bill-details.ts的构造函数中设置为空对象:

constructor(...){
  if(! this.billItem){
    this.billItem={}
  }
}

【讨论】:

  • [(ngModel)] 呢?
猜你喜欢
  • 1970-01-01
  • 2017-09-05
  • 2019-02-05
  • 2019-07-28
  • 1970-01-01
  • 1970-01-01
  • 2018-12-08
  • 2018-02-20
  • 1970-01-01
相关资源
最近更新 更多