angular – 自定义验证访问表单组件
发布时间:2020-12-17 17:11:21 所属栏目:安全 来源:网络整理
导读:我想为angular2做一个自定义验证.此验证必须访问表单的另一个组件.这可能吗? 我的模板 input type="tekst" id="startDate" name="startDate" [(ngModel)]="model.startDate" #startDate="ngModel" input type="tekst" id="endDate" name="endDate" [(ngMode
我想为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的更多信息. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |