加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

编写一个完整的Angular4 FormText 组件

发布时间:2020-12-17 08:39:05 所属栏目:安全 来源:网络整理
导读:组件定义 import { Component,Output,Input,forwardRef,EventEmitter} from '@angular/core';import {ControlValueAccessor,NG_VALUE_ACCESSOR} from '@angular/forms';@Component({ selector: 'form-text',template: ` div label{{label}}:/label input ty

组件定义

import { Component,Output,Input,forwardRef,EventEmitter} from '@angular/core';
import {ControlValueAccessor,NG_VALUE_ACCESSOR} from '@angular/forms';

@Component({
  selector: 'form-text',template: `
    <div >
        <label>{{label}}:</label>
        <input type="text"  [(ngModel)]="value"
        placeholder="{{placeholder}}" >
    </div>
  `,providers: [
    {
      provide:NG_VALUE_ACCESSOR,useExisting:forwardRef(()=>FormTextComponent),multi:true
    }
  ]
})
export class FormTextComponent implements ControlValueAccessor {
 
  @Input() label:string = '';
  @Input() placeholder: string='';

  @Output() onChange: EventEmitter<any> = new EventEmitter<any>();
  
  public innerValue: any;
  public changeFn: Function = () => {};
 

  get value(): any {
    return this.innerValue;
  };

  set value(v: any) {
    if (v !== this.innerValue) {
      this.innerValue = v;
      this.changeFn(v);
    }
  }


  writeValue(value: any) {
    if (value !== this.innerValue) {
      this.innerValue = value;
    }
  }

  registerOnChange(fn: any) {
    this.changeFn = fn;
  }

  registerOnTouched(fn: any) {
    //
  }

}

组件使用

<form-text [(ngModel)]="mobile" [placeholder]="placeholder" [label]="label"></form-text>
<p>{{mobile}}</p>

需要注意的点:

1.需要配置组件的providers2.需要实现ControlValueAccessor接口

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读