下面是我的Angular组件:

@Component( {
    selector: 'input-extra-field',
    template: `
            <div class="form-group" [formGroup]="formGroup" >
                <switch [attr.title]="field.etiquette" 
                    [attr.value]="field.valeur" [(ngModel)]="field.valeur"
                    [formControl]="fieldControl" [attr.id]="name" [attr.disabled]="disabled">
                </switch>
                <error-messages [control]="name"></error-messages>
            </div>
    `
} )

这是我的班级:

export class SwitchExtraField extends ExtraField {
    @Input() field: ExtraFormField;
    @Input() entity: { fields: Object };
    @Input() formGroup: FormGroup;

    constructor( formDir: NgForm ) {
        super( null, null, formDir );
    }

    get disabled(): string {
        if ( this.field && !!this.field.saisissable && !this.field.saisissable )     {
            return 'disabled';
        }
        return null;
    }
}

这是我编译时得到的错误:

ERROR Error: No value accessor for form control with unspecified name attribute
  at _throwError (forms.es5.js:1918)
  at setUpControl (forms.es5.js:1828)
  at FormControlDirective.webpackJsonp.../../../forms/@angular/forms.es5.js.FormControlDirective.ngOnChanges (forms.es5.js:4617)

当我改变元素开关输入它工作,知道我使用相同的结构到其他组件,它工作得很好。


当前回答

在我的情况下,我使用指令,但没有导入它在我的模块。ts文件。Import修复了它。

其他回答

你有没有试过移动你的[(ngModel)]到div而不是在你的HTML开关?我在我的代码中出现了同样的错误,这是因为我将模型绑定到<mat-option>而不是<mat-select>。虽然我没有使用表单控件。

在我的情况下,我有一个<TEXTAREA>标签从旧的html转换到angular。必须更改为<textarea>。

我还创建了一个自定义控件。 解决此问题的方法如下:

constructor(
  @Optional() @Self()
  readonly ngControl: NgControl,
) {
  this.ngControl.valueAccessor = this;
}

我也犯了同样的错误,只需要在module.ts中导入表单模块

import { FormsModule } from '@angular/forms';
    
@NgModule({
    imports: [FormsModule]
)}

我有同样的错误-我不小心绑定了[(ngModel)]到我的mat-form-field而不是input元素。