[Angular] Custom directive Form validator

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
    );
  }

 

posted @   Zhentiw  阅读(329)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示