错误TypeError:control.registerOnChange不是函数

时间:2018-02-13 09:21:40

标签: arrays angular forms typescript setvalue

我在html中的角色显示权限有问题。我的HTML代码如下:

  <div class="row">
    <select multiple formControlName="sp_id" id="permission_id" materialize="material_select" [materializeSelectOptions]="permissions">
      <option value="" disabled selected>Select Permissions</option>
      <option *ngFor="let permission of permissions" [value]="permission.permission_id">{{permission.permissin_desc}}</option>
    </select>
  </div>

JSON

{
    "StatusCode": 0,
    "StatusMessage": "OK",
    "StatusDescription": [
        {
            "permission_id": 1,
            "permission_desc": "getallclient"
        },
        {
            "permission_id": 2,
            "permission_desc": "createclient"
        },
        {
            "permission_id": 3,
            "permission_desc": "deleteclient"
        },
        {
            "permission_id": 4,
            "permission_desc": "updateclient"
        },.......]

我的tscode

  this.editclientForm = this.fb.group({
      'name': new FormControl('', Validators.required),
      'active': new FormControl('', Validators.required),
      'sp_id': this.fb.array([])
    });

//在html中填充我的表单。目前,我的问题只是sp_id,不能在html中显示。名称和活动都可以。 错误是:control.registerOnChange不是函数

 populateClientRole() {
    this.activatedRoute.params.subscribe(
      params => {
        this.rs.getRoleById(params['id']).subscribe(
          role => {
            this.role = role;
            this.editclientForm.controls['name'].setValue(role.name);
            this.editclientForm.controls['active'].setValue(role.active);
            this.editclientForm.controls['sp_id'].patchValue(role.sp_id);
             }
        );
      }
    );
  }

你能建议我,请问有什么问题?

1 个答案:

答案 0 :(得分:0)

patchValue()接受key-valueformControlName: any对的对象。 您的情况是,用下面的代码行替换最后的分配:

this.editclientForm.patchValue({sp_id: role.sp_id});

希望,这将解决您的问题。