时间:2021-05-25
在 Angular 中,对于表单元素,通过 [(ngModel)] 即可以简单地实现双向绑定。对于自定义组件而言,希望实现同样的效果可以怎么做呢?
1 实现自定义组件的 ngModel 指令
如果希望自定义组件能够具有与表单元素相同的 ngModel 效果,可以通过在组件内实现 ControlValueAccessor 接口达到目的。
对于 [(ngModel)] ,需要至少实现该接口的如下方法:
interface ControlValueAccessor { writeValue(obj: any): void registerOnChange(fn: any): void registerOnTouched(fn: any): void}最简单的核心实现示例参考如下。
import { ControlValueAccessor } from '@angular/forms/src/directives';import { Component, forwardRef, Input } from '@angular/core';import { NG_VALUE_ACCESSOR } from '@angular/forms';@Component({ selector: 'custom-input', template: `<input [(ngModel)]="value"/>`, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => UnionInputComponent), multi: true } ]})export class CustomInputComponent implements ControlValueAccessor { constructor() { } private innerValue: any = ''; private onTouchedCallback: () => void = function () { }; private onChangeCallback: (_: any) => void = function () { }; get value(): any { return this.innerValue; } set value(v: any) { if (v !== this.innerValue) { this.innerValue = v; this.onChangeCallback(v); } } /** * model view -> view value */ writeValue(value: any) { if (value !== this.innerValue) { this.innerValue = value; } } /** * view value ->model value */ registerOnChange(fn: any) { this.onChangeCallback = fn; } registerOnTouched(fn: any) { this.onTouchedCallback = fn; }}2 使用 get/set 关键字实现父子组件的双向绑定
其实实现双向绑定内部的本质原理就是父子组件的事件绑定机制。简单举例如下。
2.1 自定义子组件定义
2.2 使用自定义组件
在需要使用组件的地方,通过 [(twoWayModel)] 即可实现双向绑定的效果。
import { Input, Output } from '@angular/core';import { Component, forwardRef, Input } from '@angular/core';@Component({ selector: 'custom-input', template: `<custom -input [(twoWayModel)]="inputValue" (twoWayModelChange)="onInputValueChange($event)"></custom>`})export class abcComponent { inputValue; onInputValueChange(val) { console.log(val); console.log(val === this.inputValue); // true }}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文介绍了ANGULAR2与D3.js集成实现自定义可视化的方法,分享给大家,具体如下:目标展现层与逻辑层分离数据与可视化组件相分离数据与视图双向绑定,实时更新
整理文档,搜刮出一个Angular2实现自定义双向绑定属性的代码,稍微整理精简一下做下分享。import{Component,OnInit,Output,Inp
Vue.js使用自定义事件的表单输入组件自定义事件可以用来创建自定义的表单输入组件,使用v-model来进行数据双向绑定。要牢记:这不过是以下示例的语法糖:所以
上篇文章给大家介绍了浅析Vue自定义组件的v-model,大家可以参考下。接下来通过本文给大家介绍vue自定义组件v-model双向绑定、父子组件同步通信的多种
python自定义异常实例详解本文通过两种方法对Python自定义异常进行讲解,第一种:创建一个新的exception类来拥有自己的异常,第二种:raise唯一