首頁 > web前端 > js教程 > 實作完整的Angular4 FormText元件需要哪些步奏

實作完整的Angular4 FormText元件需要哪些步奏

php中世界最好的语言
發布: 2018-04-14 14:42:54
原創
1480 人瀏覽過

這次帶給大家實作完整的Angular4 FormText元件需要哪些步奏,實作完整Angular4 FormText元件的注意事項有哪些,以下就是實戰案例,一起來看一下。

本文主要介紹如何寫一個完整的Angular4 FormText 元件,分享給大家,也給自己留個筆記

元件定義

import { Component, Output, Input, forwardRef, EventEmitter} from '@angular/core';
import {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';
@Component({
 selector: 'form-text',
 template: `
  <p >
    <label>{{label}}:</label>
    <input type="text" [(ngModel)]="value"
    placeholder="{{placeholder}}" >
  </p>
 `,
 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>
登入後複製

需要注意的點:

需要配置元件的providers
需要實作ControlValueAccessor介面                                        

了本文案例時你已掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦讀取:

js如何符合計算font-size

#操作modal單次載入資料


以上是實作完整的Angular4 FormText元件需要哪些步奏的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板