内容简介:在 Angular 自定义表单控件,有时你想要的输入不是标准的文本输入、选择或复选框。通过实现ControlValueAccessor 接口并将组件注册为 NG_VALUE_ACCESSOR,您可以将自定义表单控件无缝地集成到模板驱动或响应表单中,就像它是本地表单一样!ControlValueAccessor 是一个接口,充当Angular API 和 DOM 元素之间的桥梁writeValue(obj:any)是将表单模型中的值写入视图中。
在 Angular 自定义表单控件,有时你想要的输入不是标准的文本输入、选择或复选框。通过实现ControlValueAccessor 接口并将组件注册为 NG_VALUE_ACCESSOR,您可以将自定义表单控件无缝地集成到模板驱动或响应表单中,就像它是本地表单一样!
ControlValueAccessor
ControlValueAccessor 是一个接口,充当Angular API 和 DOM 元素之间的桥梁
export interface ControlValueAccessor {
writeValue(obj: any) : void
registerOnChange(fn: any) : void
registerOnTouched(fn: any) : void
}
writeValue(obj:any)是将表单模型中的值写入视图中。
writeValue(value: any): void {
this._renderer.setProperty(this._elementRef.nativeElement, 'value', value);
}
registerOnChange(fn:any)是一个方法,用于注册在视图中的某些内容发生更改时应调用的处理程序。它获取一个函数,告诉其他表单指令和表单控件更新其值。
registerOnChange(fn: (_: any) => void): void {
this._onChange = fn;
}
registerOnTouched(fn:any)与registerOnChange()此类似,它专门为控件接收触摸事件时注册一个处理程序。
registerOnTouched(fn: any): void {
this._onTouched = fn;
}
setDisabledState?(isDisabled: boolean): void; 是一个可选的方法,设置自定义表单的状态
setDisabledState(isDisabled: boolean): void {
this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);
}
AbstractValueAccessor
我们可以把 ControlValueAccessor 中的方法写在一个抽象类中,不同的组件可以实现这个基类
export abstract class AbstractValueAccessor implements ControlValueAccessor {
private _value: any = '';
get value(): any {
return this._value;
}
set value(v: any) {
if (v !== this._value) {
this._value = v;
this.onChange(v);
this.onTouched();
}
}
writeValue(value: any) {
this._value = value;
}
onChange = (_) => {};
onTouched = () => {};
registerOnChange(fn: (_: any) => void): void {
this.onChange = fn;
}
registerOnTouched(fn: () => void): void {
this.onTouched = fn;
}
}
export function MakeProvider(type: any): { provide: any, useExisting: any, multi: boolean} {
return { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => type), multi: true };
}
Example
自定义一个 list 控件,可以选择年级
以上所述就是小编给大家介绍的《Angular 使用 ControlValueAccessor 创建自定义表单控件》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- vue 表单控件与绑定(七)
- Angular 从入坑到挖坑 - 表单控件概览
- Angular ControlValueAccessor - 自定义表单控件介绍与实战
- Angular ControlValueAccessor:自定义表单控件介绍与实战
- Chrome 83 Beta 发布:与 Edge 合作改进的表单控件
- Chrome 83 稳定版发布:新的跨域政策、表单控件,和改进的 Web 体验
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Learning Vue.js 2
Olga Filipova / Packt Publishing / 2017-1-5 / USD 41.99
About This Book Learn how to propagate DOM changes across the website without writing extensive jQuery callbacks code.Learn how to achieve reactivity and easily compose views with Vue.js and unders......一起来看看 《Learning Vue.js 2》 这本书的介绍吧!