这个错误表示在表单控件中找不到相应的值访问器。一种可能的解决方法是确保表单控件指令(如“NgModel”或“FormControlName”)与表单控件的HTML元素一起使用。例如:
或者
如果使用自定义表单控件(例如,使用“controlValueAccessor”创建的自定义组件),则必须向表单控件指令添加自定义控件。例如:
import { Component, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';
@Component({
selector: 'my-custom-control',
template:
,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => MyCustomControlComponent),
multi: true
}
]
})
export class MyCustomControlComponent implements ControlValueAccessor {
value: any;
onChange: any = () => { }; onTouch: any = () => { };
writeValue(value: any) { this.value = value; this.onChange(value); this.onTouch(value); }
registerOnChange(fn: any) { this.onChange = fn; }
registerOnTouched(fn: any) { this.onTouch = fn; }
setDisabledState?(isDisabled: boolean) { // do something } }
然后,在表单的HTML中使用该自定义组件: