码迷,mamicode.com
首页 > 其他好文 > 详细

[Angular] Custom directive Form validator

时间:2017-08-21 09:45:58      阅读:171      评论:0      收藏:0      [点我收藏+]

标签:forms   bsp   gif   can   check   pre   ror   abstract   ast   

Create a directive to check no special characters allowed:

import {Directive, forwardRef} from ‘@angular/core‘;
import {AbstractControl, NG_VALIDATORS, Validator} from ‘@angular/forms‘;
@Directive({
  selector: `[formControl][no-special-chars], 
             [formControlName][no-special-chars], 
             [ngModel][no-special-chars]`,
  providers: [
    {
      multi: true,
      provide: NG_VALIDATORS,
      useExisting: forwardRef(() => NoSpecialCharsValidator)
    }
  ]
})

export class NoSpecialCharsValidator implements Validator {
  validate(c: AbstractControl): { [key: string]: any; } {
    const res = /[~`!#$%\^&*+=\-\[\]\\‘;,/{}|\\":<>\?]/g.test(c.value);
    return res ? {special: true}: null;
  }
}

 

        <div class="meal-form__name">
          <label>
            <h3>Meal name</h3>
            <input type="text"
                   no-special-chars
                   formControlName="name"
                   placeholder="e.g. English Breakfast">
            <div class="error" *ngIf="noSpecials">
              Cannot contain special characters
            </div>
          </label>
        </div>
  get noSpecial() {
    return (
      this.form.get(‘name‘).hasError(‘special‘) &&
        this.form.get(‘name‘).touched
    );
  }

 

[Angular] Custom directive Form validator

标签:forms   bsp   gif   can   check   pre   ror   abstract   ast   

原文地址:http://www.cnblogs.com/Answer1215/p/7402283.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!