forms - Angular2 - 访问验证指令中的 AbstractControl 实例

标签 forms validation angular typescript angular2-directives

我必须从验证器指令内部触发验证。

这是我的指令。它按预期工作。但是我希望它在验证器函数更改时触发验证过程。 IE。当其输入变量 maxDate 更改时。

我怎样才能做到这一点?

如果我可以在构造函数中访问 AbstractControl 实例,我就可以轻松地做到这一点。但是我想不出办法。

import { AbstractControl, FormGroup, ValidatorFn, Validator, NG_VALIDATORS, Validators } from '@angular/forms';
import { Directive, Input, OnChanges, SimpleChanges, EventEmitter } from '@angular/core';


function parseDate(date: string):any {  
  var pattern = /(\d{2})-(\d{2})-(\d{4})/;
  if (date) {
    var replaced = date.search(pattern) >= 0;    
    return replaced ? new Date(date.replace(pattern,'$3-$1-$2')) : null;
  }

  return date;
}


export function maxDateValidator(maxDateObj): ValidatorFn {
  return (control:AbstractControl): {[key: string]: any} => {    
    const val = control.value;

    let date = parseDate(val);
    let maxDate = parseDate(maxDateObj.max);    

    if (date && maxDate && date > maxDate) {
      return {
        maxDateExceeded: true
      };
    }
    return null;
  };
}

...

@Directive({
  selector: '[maxDate]',  
  providers: [{provide: NG_VALIDATORS, useExisting: maxDateDirective, multi: true}]  
})
export class maxDateDirective implements Validator, OnChanges {
  @Input() maxDate: string;

  private valFn = Validators.nullValidator;

  constructor() { }

  ngOnChanges(changes: SimpleChanges): void {
    const change = changes['maxDate'];
    if (change) {
      const val: string  = change.currentValue;      
      this.valFn = maxDateValidator(val);
    }
    else {
      this.valFn = Validators.nullValidator;
    }
    //This is where I want to trigger the validation again.
  }

  validate(control): {[key: string]: any} {
    return this.valFn(control);
  }
}

用法:

  <input type="text" [(ngModel)]="deathDateVal">

  <input class="form-control"          
          type="text"
          tabindex="1"
          [maxDate]="deathDateVal"
          name="will_date"
          [textMask]="{pipe: datePipe, mask: dateMask,  keepCharPositions: true}"
          ngModel
          #willDate="ngModel">

最佳答案

这是我刚刚想到的:

@Directive({
  selector: '[maxDate]',  
  providers: [{provide: NG_VALIDATORS, useExisting: maxDateDirective, multi: true}]  
})
export class maxDateDirective implements Validator, OnChanges {
  @Input() maxDate: string;

  private valFn = Validators.nullValidator;
  private control:AbstractControl;

  constructor() { }

  ngOnChanges(changes: SimpleChanges): void {
    const change = changes['maxDate'];
    if (change) {
      const val: string  = change.currentValue;      
      this.valFn = maxDateValidator(val);
    }
    else {
      this.valFn = Validators.nullValidator;
    }

    if (this.control) {
      this.control.updateValueAndValidity(this.control);
    }
  }

  validate(_control:AbstractControl): {[key: string]: any} {
    this.control = _control;
    return this.valFn(_control);
  }
}

它有效。 Validate 在初始化时被调用,所以我只存储它的参数。 虽然很丑,但是很管用。

关于forms - Angular2 - 访问验证指令中的 AbstractControl 实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41880232/

相关文章:

forms - Scala/Play 框架 : How to modify fields in Form object before validation

javascript - Angular App 订阅前 Observable 过滤结果

asp.net-mvc - 验证嵌套模型

ruby-on-rails - ActiveRecord 未使用 .build 在 has_many 关联上设置外键

php - 验证 Opencart

javascript - 在 Angular 组件中显示嵌套的 Json

angular - 如何在 Angular 2 typescript 项目中更改 body 类别

javascript - IE11 中的表单文件输入未正确重置

php - 通过 GET 提交表单到重写的 URL

javascript - 取消选中复选框时从广播中删除 "checked"