angular4 自定义表单组件
自定义表单组件分为单值组件和多值组件.
单值组件:input/select/radio/textarea
多值组件:checkbox/tree组件
条件:
1.必须实现ControlValueAccessor接口
不同输入控件的数据更新方式不一样。
比如input是设置value值,而checkbox是设置checked属性。
因此不同类型的输入控件都有一个ControlValueAccessor来更新视图
export interface  ControlValueAccessor{
     writeVlaue(obj:any) :void;             //model->view
     registerOnchange(fn:any) :void;    //view->model
     registerOnTouched(fn:any):void;
     setDisabledState?( isDisabled:boolean):void
}
//实现
writeValue(value:any){
   if(value!=this.innerVal){
       this.innerVal=value;
   }
}
2.必须注册成为表单组件(使用providers属性)
注释:
1.provide:将组件注册到DI框架,让其成为一个可被表单访问的组件
2.useExisting:让组件暴露对应的validatate方法实现表单验证
3.multi:为true时表示这个token对应多个依赖项,可在多个表单里使用,互不影响
@Component({
  selector:'nw-input',
  templateUrl:'./nw-input.component.html',
  styleUrls:'./nw-input.component.scss',
  providers:[
      provide:NG_VALUE_ACCESSOR,
      useExisting:forwardRef(()=>nwInputComponent),
      multi:true
  ]
})
具体实现:
1.如果是单值表单组件,使用FormControl
//nw-select.component.ts
@Component({
  selector:'nw-select',
  templateUrl:'./nw-select.component.html',
  styleUrls:'./nw-select.component.scss',
  providers:[
      provide:NG_VALUE_ACCESSOR,
      useExisting:forwardRef(()=>NwSelectComponent),
       multi:true
  ]
})
export class NwSelectComponent implements ControlValueAccessor{
    selectFormControl:FormControl=new FormControl();
    getControl(vfn:ValidatorFn[]):FormControl{
      if(!this.selectFormControl){
           this.selectFormControl=new FormControl('',vfn)
      }
     return this.selectFormControl
   }
}
//xx.component.ts
export class xxComponent implements OnInit {
  thatForm:formGroup;
  @ViewChild('xxComp')
  xxComp:NwSelectComponent;
   ngOnInit(){
    xx:this.xxComp.getControl([Validator.required,Validators.minLength(5)])   //验证条件还是数组
  }
}
    
2.如果是多值表单组件,使用FormArray
//nw-checkbox.component.ts
@Component({
  selector:'nw-checkbox',
  templateUrl:'./nw-checkbox.component.html',
  styleUrls:'./nw-checkbox.component.scss',
  providers:[
      provide:NG_VALUE_ACCESSOR,
      useExisting:forwardRef(()=>NwCheckboxGroupComponent),
       multi:true
  ]
})
export class NwCheckboxGroupComponent implements ControlValueAccessor{
    checkboxFormArray:FormArray=new FormArray([]);
    getControls(vfn:ValidatorFn):FormArray{
     if(!this.checkboxkFormArray){
        this.checkboxFormArray=new FormArray([],vfn);
    }
   }
    cleanControls(){
      while(this.checkboxFormArray.controls.length!==0){
           this.checkboxFormArray.removeAt(0)
     }
   pushControl(id:any){
      this.checkboxFormArray.push(new FormControl(id))
   }
 }
}
//xx.component.ts
export class xxComponent implements OnInit {
   thatForm:FormGroup;
   @ViewChild(xxComp)
   xxComp:NwCheckboxGroupComponent;
   ngOnInit(){
     this.thatFom=this.formBuilder.group({
        xx:this.xxComp.getControls(Valitators.required)  //验证条件不再允许数组了
    })
  }
}
  
angular4 自定义表单组件的更多相关文章
- Vue组件之自定义表单组件
		
今天又看了一遍vue的文档,记得之前学习的时候,官方文档中有提过,v-model指令是一个语法糖,做两件事,一个是给表单控件元素绑定value,第二个是当输入时更新绑定的值,不过后来在"表单 ...
 - 实现Ant Design 自定义表单组件
		
Ant Design 组件提供了Input,InputNumber,Radio,Select,uplod等表单组件,但实际开发中这是不能满足需求,同时我们希望可以继续使用Form提供的验证和提示等方法 ...
 - angular4  自定义表单验证Validator
		
表单的验证条件有时候满足不了需求就可以自定义验证 唯一要求返回是ValidatorFn export interface ValidatorFn{ (c:AbstractControl):Valida ...
 - Angular4——7.表单处理
		
在Angular中存在两种表单处理方式: 模版驱动式表单 表单的数据模型是通过组件模版中的相关指令来定义的.由于使用这种方式定义表单的数据模型时,我们会受限于HTML的语法,所以,模版驱动方式只适用于 ...
 - 【.net+jquery】绘制自定义表单(含源码)
		
前言 两年前在力控的时候就想做一个类似的功能,当时思路大家都讨论好了,诸多原因最终还是夭折了.没想到两年多后再这有重新提出要写一个绘制表单的功能.对此也是有点小激动呢?总共用时8.5天的时间基本功能也 ...
 - Orchard创建自定义表单
		
本文链接:http://www.cnblogs.com/souther/p/4520130.html 主目录 自定义表单模块可以用来获取网站前台用户的信息.自定义表单需要与一个内容类型结合使用.它可以 ...
 - Angular19 自定义表单控件
		
1 需求 当开发者需要一个特定的表单控件时就需要自己开发一个和默认提供的表单控件用法相似的控件来作为表单控件:自定义的表单控件必须考虑模型和视图之间的数据怎么进行交互 2 官方文档 -> 点击前 ...
 - Winform自定义表单(转)
		
出处:http://www.newlifex.com/showtopic-167.aspx 好吧,附件真的损坏了,原始代码我也没有了,再提取我也没精力了,不好意思,哪位之前下过可以重发一遍吗?不过即使 ...
 - ZKEACMS 自定义表单的使用
		
ZKEACMS Core 2.2 已经发布了,其中主要添加了自定义表单的功能.使用自定义表单的功能,您可以在几分钟内就创建一个表单,并用它来收集一些信息.导出收集的信息,就可以做一些统计分析. 创建表 ...
 
随机推荐
- 二分图——poj2239
			
水题 /* n门课,每门课有一个时间t 要求最大的n->t的匹配 */ #include<iostream> #include<cstring> #include< ...
 - make: 警告:检测到时钟错误。您的创建可能是不完整的。
			
我在make的时候也出现了同样的问题,不过不是什么大问题,这个不影响编译结果,但是强迫症还是希望能解决掉 分析原因可能是:服务器上的文件最后修改时间比当前时钟要晚 解决办法:用touch 命令把源程序 ...
 - 12DUILib经典教程(实例)
			
Duilib经典实例教程:1基本框架:一个简单的Duilib程序一般是下面这个样子的:://Duilib使用设置部分:#pragmaonce:#defineWIN32_LEAN_AND_ME:#def ...
 - 单独安装Babel或者Less
			
1.直接安装Babel法: 1)初始化自动创建package.json npm init 2)首先全局安装Babel. npm install -g babel-cli 3)项目安装Babel. np ...
 - Cordova 常用命令及插件
			
安装 cordova: npm install -g cordova 创建应用程序 cordova create hello com.example.hello HelloWorld 添加平台 co ...
 - php数据结构课程---6、常见排序有哪些
			
php数据结构课程---6.常见排序有哪些 一.总结 一句话总结: 冒泡排序(Bubble sort):依次交换 选择排序 ( Selection Sort ):在未排序序列中找到最小(大)元素,依次 ...
 - 【breathandlife】气势磅礴、比较好听的旋律有哪些?
			
[breathandlife]气势磅礴.比较好听的旋律有哪些? 分享:yunbest作者:来源:2015-10-26 专题:breathandlife [breathandlife]气势磅礴.比较好听 ...
 - Error:Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
			
ylbtech-Error:Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerF ...
 - Android基础控件ScrollView滚动条的使用
			
1.简介 ScrollView是一个FrameLayout的容器,不过在他的基础上添加了滚动,允许显示的比实际多的内容!另外,只能够往里面放置一个子元素,可以是单一的组件,又或者一个布局包裹着的复杂的 ...
 - 关于群晖的sata扩展卡选择