我想如果我选择年度单选按钮,选择选项值2018,现在没有人选中

问题描述 投票:0回答:1

我想如果我选择年度单选按钮,选择选项值2018,现在没有人选中。

类代码是:

alls:string='';
type:string ='1';
yData = [{"Year":2018},{"Year":2017},{"Year":2016}]`enter code here`

这是模板代码:

<div>
            <div class="radio">
                <label><input type="radio" [(ngModel)]="type" name="type" value="1">All Search</label>
            </div>
            <div class="radio">
                <label><input type="radio" [(ngModel)]="type" name="type" value="2">Album Title </label>
            </div>
            <div class="radio">
                <label><input type="radio" [(ngModel)]="type" name="type" value="3">Year </label>
            </div>
            <div class="radio">
                <label><input type="radio" [(ngModel)]="type" name="type" value="4">Event Date </label>
            </div>
            <div class="radio">
            <label><input type="radio" [(ngModel)]="type" name="type" value="5">Description </label>
            </div>

    </div>


<div *ngIf="type === '1'">All Search:<input type="text" [(ngModel)]="alls" /><br></div>
<div *ngIf="type === '2'">Album Title: {{this.type}} <input type="text" [(ngModel)]="alls" /></div>
<div *ngIf="type === '3'">Year: {{this.type}} alls {{yData[0]["Year"]}}
<select [(ngModel)]="alls">
<option *ngFor="let yrow of yData" [value]="yrow.Year"> {{yrow.Year}} </option>
</select>
</div>
<div *ngIf="type === '4'">Event Date: {{this.type}} <input type="date" [(ngModel)]="alls" /></div>
<div *ngIf="type === '5'">Description:  {{this.type}}  <input type="text" [(ngModel)]="alls" /></div>

如上面的角度5代码。

angular angular2-forms angular5
1个回答
0
投票

您必须说Angular如果更改“类型”会发生什么。因此,您必须“分离”ngModel和ngModelChange。如果你使用简单的[(ngModel)]你只能改变变量“type”

<input type="radio" value="3" [ngModel]="type" 
           (ngModelChange)="type = 3;alls=yData[0].Year">

实现相同的其他方法是使用getter setter并使用[(ngModel)]

在你的.ts

_type:number;
get type(){
   return _type;
}
set type(value:any)
{
   this._type=value;
   if (this._type==3)
      this.alls=this.yData[0].Year
}

其他方式是使用Reactive Form并进行更改,请参阅https://angular.io/guide/reactive-forms#reactive-forms

© www.soinside.com 2019 - 2024. All rights reserved.