4

我试图在 Angular 2 中进行自定义验证,我已经包含了我所知道的内容,但我无法验证

import { FORM_DIRECTIVES, AbstractControl, ControlGroup
,FormBuilder,Control, Validators } from 'angular2/common';
@Component({
selector : 'cusValidate',
template: `
 <form [ngFormModel] = "myform" (ngSubmit) = "onSubmit()">
 <lable>Credit Card Number</lable>
 <div>
 <input type = "text" [ngFormControl] = "inputfield"/>
 <div [class.has-error] = '!inval'>
  </div>
 </div>
 <button type = "submit">Submit</button>
 </form>
`,
directives : [FORM_DIRECTIVES]

})
export class cusValidation{
myform : ControlGroup;
inputfield : AbstractControl;

constructor(fb : FormBuilder){
   this.myform = fb.group({
        'inputfield' : ['' , Validators.compose([Validators.required
,this.formValidator])]
    })
   this.inputfield = this.myform.controls['inputfield']
}

 formValidator(val : Control) :any {
     if(val.value.match(/^123/)){
         return {inval : true};
     }
 }

onSubmit(){
    console.log('submit function called')
}
}
bootstrap(cusValidation);

验证器函数也在我包含的其他文件中,但这里它在类中并且我使用 this.function 访问,以及如何应用适当的 twitter 引导程序

4

2 回答 2

4

您使用的是 Angular2,那么您可以使用 html5 表单字段。你为什么不使用' <input type ="number"/>

于 2016-02-25T20:51:45.017 回答
1

我试图在这个Plunker中重现它,并且验证被称为很好。

我不确定你期望什么。目前,输入formValidator时表示错误123,其他所有内容都被认为是有效的('ab','12','xyz123')。

如果要指示错误,请返回带有错误键和任意值的对象(例如错误消息)。

如果你想表明没有错误(值是有效的)然后返回null

formValidator(val : Control) :any {
     if(val.value.match(/.*[^0-9].*/)){
         return {inval : true};
     }
 }

更新的 Plunker

于 2016-02-25T19:47:15.717 回答