在Angular 9中,NgModel在自定义指令中的行为与Angular 7有所改变。在Angular 7中,我们可以直接使用NgModel来绑定表单控件的值,而在Angular 9中,我们需要使用ControlValueAccessor接口来自定义指令的行为。下面是一个解决方法的代码示例:
首先,创建一个自定义指令,实现ControlValueAccessor接口:
import { Directive, ElementRef, forwardRef, HostListener, Renderer2 } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
@Directive({
selector: '[myDirective]',
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => MyDirective),
multi: true
}
]
})
export class MyDirective implements ControlValueAccessor {
constructor(private renderer: Renderer2, private elementRef: ElementRef) { }
private onChange: any = () => { };
private onTouch: any = () => { };
writeValue(value: any): void {
this.renderer.setProperty(this.elementRef.nativeElement, 'value', value);
}
registerOnChange(fn: any): void {
this.onChange = fn;
}
registerOnTouched(fn: any): void {
this.onTouch = fn;
}
setDisabledState(isDisabled: boolean): void {
this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', isDisabled);
}
@HostListener('input', ['$event.target.value'])
onInput(value: any): void {
this.onChange(value);
this.onTouch();
}
}
然后,在模板中使用自定义指令:
这样,当输入框的值发生变化时,自定义指令的onInput方法会被调用,并通过ControlValueAccessor接口将值传递给[(ngModel)]。这种方式保持了与Angular 7中NgModel的行为一致。