我使用Angular2和我有2种选择:角2更改禁用/启用选择选项
<div ng-controller="ExampleController">
<form name="myForm">
<label for="companySelect"> Company: </label>
<select name="companySelect" id="companySelect">
<option *ngFor="let company of companies"
value="{{company.id}}"> {{company.name}}
</option>
</select>
<label for="documentTypeSelect"> Type: </label>
<select name="documentTypeSelect" id="documentTypeSelect">
<option value="type1">type1</option>
<option value="type2">type2</option>
<option value="type3">type3</option>
</select>
</form>
<hr>
</div>
我想这取决于第一选择改变第二选择选项。我可以用
company.companyRelations.pop得到类型(布尔值)()。TYPE1
company.companyRelations.pop()。TYPE2
而现在,例如,如果type1为false,应该禁用second select中的选项,如果type2为true,则应启用选项。那可能吗?
编辑:
公司中选择具有是真的还是假的deasdv,INVOIC和订单属性。我怎样才能将这些属性传递到component.ts属性?事件或事件可能吗?我想例如
company.companyRelations.pop()。DESADV
对于所选择的公司,它将会改变你在第二个禁用的选项。
HTML
<form name="myForm">
<label for="companySelect"> Company: </label>
<select class="form-control" name="companySelect" id="companySelect"
[(ngModel)]="companySelect" (ngModelChange)="onChange($event)">
<option [ngValue]="undefined" disabled selected>Select...</option>
<option *ngFor="let company of companies" [ngValue]="company.id">
{{company.name}}</option>
</select>
<select name="documentTypeSelect" id="documentTypeSelect">
<option [ngValue]="undefined" disabled selected>Select...</option>
<option [disabled]="!desadv" value="desadv">desadv</option>
<option [disabled]="!invoic" value="invoic">invoic</option>
<option [disabled]="!orders" value="orders">orders</option>
</select>
</form>
component.ts
desadv: boolean = false;
invoic: boolean = false;
orders: boolean = false;
这里将是这样的:
onChange(event) {
if(event.desadv) {
this.desadv = true;
}
}
我的解决办法:
HTML
<form name="myForm">
<label for="companySelect"> Company: </label>
<select name="companySelect" id="companySelect" [(ngModel)]="companySelect"
(ngModelChange)="onChange($event)">
<option [ngValue]="undefined" disabled selected>Select...</option>
<option *ngFor="let company of companies" [ngValue]="company">
{{company.name}}</option>
</select>
<label for="documentTypeSelect"> Type: </label>
<select name="documentTypeSelect" id="documentTypeSelect">
<option [ngValue]="undefined" disabled selected>Select...</option>
<option [disabled]="!desadv" value="desadv">desadv</option>
<option [disabled]="!invoic" value="invoic">invoic</option>
<option [disabled]="!orders" value="orders">orders</option>
<option [disabled]="!recadv" value="orders">recadv</option>
<option [disabled]="!shipment" value="orders">shipment</option>
</select>
component.ts
onChange(event) {
this.desadv = event.companyRelations[0].desadv;
this.invoic = event.companyRelations[0].invoic;
this.orders = event.companyRelations[0].orders;
this.recadv = event.companyRelations[0].recadv;
this.shipment = event.companyRelations[0].shipment;
}
如果[禁用] = “!DESADV” 这将是能够在选项列表。你想禁用** [disabled] =“desadv”**更改它 – Chandru
它必须在开始时被禁用,如果公司的属性被启用,它会改变,所以没关系。 – Helosze
好的,我解决了这个问题。 – Helosze