2

我正在使用 FormBuilder 向数据库添加值。

 this.formUser = this._form.group({
   "firstName": new FormControl('', [Validators.required]),
  "lastName": new FormControl('', [Validators.required]),
  "externalCompany": new FormControl('', [Validators.required])
})

在添加这些值之前,我想将下拉列表(外部公司)的值设置为我事先提交的值

<select class="form-control" id="companyExternal" formControlName="externalCompany" (ngModelChange)=onChangeExternalC($event)>
     <option value="" >Select existing company...</option>
     <option value="{{company}}" *ngFor="let company of externalCompanies">{{company}}</option>
     <option value="Company name..." >ADD ANOTHER...</option>
</select>

我试过这个

this._commServe.addExternalCompany(company).subscribe((data) => {   
  this.formUser.value.externalCompany = company.CompanyName;
}, (error) => {
  this.errorMessage = <any>error;
})

我也尝试使用 ngModel 也没有按预期工作。

例如,在不求助于 jQuery 的情况下设置此下拉列表的选定状态的最佳方法是什么

4

1 回答 1

3

您可以selected在模型中具有选定值的选项上设置属性。

[attr.selected]="selectedExternalCompany"

使用该html模板:

<select class="form-control" id="companyExternal" formControlName="externalCompany" (ngModelChange)=onChangeExternalC($event)>
     <option value="" >Select existing company...</option>
     <option value="{{company}}" 
         *ngFor="let company of externalCompanies" 
         [attr.selected]="selectedExternalCompany"
         >{{company}}</option>
     <option value="Company name..." >ADD ANOTHER...</option>
</select>

并且在组件中设置selectedExternalCompany选择框何时更改并将其用作模型。

这是基于答案如何在 Angular 2 中添加条件属性?

于 2017-04-11T15:15:37.253 回答