问题描述
我正在尝试使用asyncPipe和[ngModel] /(ngModelChange)使用可观察字段进行基于选择/选项的下拉列表工作.我的代码出了点问题,因为在运行时控制台会输出[object Object](请参见下图).
令我困惑的是,如果我使用[value] =“payPeriod.id”,它工作正常,并且在setSelectedPayPeriod(…)方面成功接收到数字ID.
component.html
<select [ngModel]="selectedPayPeriod | json" (ngModelChange)="setSelectedPayPeriod($event)"> <option *ngFor="let payPeriod of (payPeriodList | async)" [value]="payPeriod">{{ payPeriod.endDate }}</option> </select>
component.ts
get payPeriodList(): Observable<PayPeriod[]> { return this._contextService.payPeriodList; } get selectedPayPeriod(): Observable<PayPeriod> { return this._contextService.selectedPayPeriod; } setSelectedPayPeriod(newValue: PayPeriod): void { console.warn(newValue); this._contextService.setSelectedPayPeriod(newValue); }
控制台输出
歉意
对不起,我对plunker不是很熟悉,也无法快速找到我可以解决的Angular 2模板.
UPD.接受的解决方案 – 由AJT_82提供
>在选项元素上使用[ngValue]而不是[value].
>在select元素上使用[ngModel] =“selectedPayPeriod | async”而不是[ngModel] =“selectedPayPeriod | json”.
<select [ngModel]="selectedPayPeriod | async" (ngModelChange)="setSelectedPayPeriod($event)"> <option *ngFor="let payPeriod of (payPeriodList | async)" [ngValue]="payPeriod">{{ payPeriod.endDate }}</option> </select>
解决方法
payPeriod是一个Object,因此如果要绑定整个对象,请使用[ngValue]而不是[value].
<option *ngFor="let payPeriod of (payPeriodList | async)" [ngValue]="payPeriod">{{ payPeriod.endDate }}</option>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。