Angularjs   发布时间:2022-04-20  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了angular – 与Select / Options和ngModel / ngModelChange一起使用的异步管道大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
问题描述

我正在尝试使用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);
}

控制台输出

angular – 与Select / Options和ngModel / ngModelChange一起使用的异步管道

歉意

对不起,我对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>
@H_450_36@解决方法
payPeriod是一个Object,因此如果要绑定整个对象,请使用[ngValue]而不是[value].

<option *ngFor="let payPeriod of (payPeriodList | asynC)" [ngValue]="payPeriod">{{ payPeriod.endDate }}</option>

大佬总结

以上是大佬教程为你收集整理的angular – 与Select / Options和ngModel / ngModelChange一起使用的异步管道全部内容,希望文章能够帮你解决angular – 与Select / Options和ngModel / ngModelChange一起使用的异步管道所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。