angular – 自定义验证访问表单组件

前端之家收集整理的这篇文章主要介绍了angular – 自定义验证访问表单组件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想为angular2做一个自定义验证.此验证必须访问表单的另一个组件.这可能吗?

我的模板

<input type="tekst" id="startDate" name="startDate" [(ngModel)]="model.startDate" #startDate="ngModel" >

<input type="tekst" id="endDate" name="endDate" [(ngModel)]="model.endDate" #endDate="ngModel" customValidator>

我的验证员

...
@Directive({
    selector: '[customValidator][ngModel][customValidator][formControl]',providers: [
        provide : NG_VALIDATORS,useExisting : forwardRef(() = > CustomValidator),Multi : true
    }]
})

export class CustomValidator impelments Validator {
    constructor(){}

    validate(c : FormControl) : {[key : string] : any} {

        // HOW TO ACCESS startDate CONTROL HERE? OR ITS VALUE? OR THE MODEL
    }

解决方法

如果要实现交叉验证,则应将验证移至祖先控件.

那么你的validate方法可能如下所示:

validate(fg: FormGroup) {
  const start = fg.get('startDate').value;
  const end = fg.get('enDate').value;

  return start !== null && end !== null && start < end 
   ? null 
   : { range: true };
};

阅读有关交叉验证here的更多信息.

猜你在找的Angularjs相关文章