最初のセレクタlevelNumの値を選択すると、最初に選択したオブジェクトがオブジェクトに表示され、2番目に選択すると2つの異なる番号が表示されますセレクタは分離されていますが、同じngModel名です。私はng-forから得る動的セレクタのためにこの方法が必要です。ここに私のコードは次のとおりです。Angular2 ngModel select
//our root app component
import {Component, Directive, Output, EventEmitter, Input, SimpleChange} from 'angular2/core'
import {Observable} from 'rxjs/Observable';
import {Observer} from 'rxjs/Observer';
//import 'rxjs/Rx';
@Component({
selector: 'my-app',
template:`
<h1>Selecting Number</h1>
<select type="number" [(ngModel)]="levelNum" (ngModelChange)="toNumber()">
<option *ngFor="let level of levels" [ngValue]="level.num">{{level.name}}</option>
</select>
<select type="number" [(ngModel)]="levelNum" (ngModelChange)="toNumber()">
<option *ngFor="let level of levels" [ngValue]="level.num">{{level.name}}</option>
</select>
{{levelNum}}
`,
})
export class AppComponent {
levelNum: any;
levels:Array<Object> = [
{num: 0, name: "AA"},
{num: 1, name: "BB"}
];
toNumber(){
this.levelNum = +this.levelNum;
console.log(this.levelNum);
}
}
チェックをあなたのtoNumber関数 – jmachnik
変数の型をArrayに変更しても同じ問題が発生した場合は、常にセレクタから最後に選択された項目だけが返されますが、選択した値をオブジェクトにプッシュする必要があります。 – user3278890
コードにplunkerを付けることができますか?コードからngModelを更新していますか? – jmachnik