Как удалить пробел и специальные символы в Mat-Input, используя RegEx - PullRequest
0 голосов
/ 15 января 2019

У меня есть форма, и я хочу поставить проверку под углом таким образом, чтобы, если пользователь вводит какой-либо специальный символ, он отображал ошибку. Форма имеет два поля Имя и Описание. В поле имени я хочу поставить проверку с помощью регулярного выражения, чтобы пользователь не мог вводить что-либо, кроме буквенно-цифровых символов.

HTML код:

 <form (ngSubmit)="(submit)" #formControl="ngForm">
                    <div class="form">
                        <mat-form-field color="accent">
                            <input
                                matInput
                                #input
                                class="form-control"
                                placeholder="name"
                                [(ngModel)]="data.projectName"
                                name="name"
                                (ngModelChange)="noWhiteSpaceOnChange()"
                                required
                                minlength="4"
                            />

                            <mat-error *ngIf="formControl.invalid">{{
                                getErrorMessage()
                            }}</mat-error>
                        </mat-form-field>
                    </div>
                   </form>

Код TypeScript: -

 noWhiteSpaceOnChange() {
    const validationRegex = /^((?!\s{1,}).)*$/
    if (!validationRegex.test(this.data.projectName)) {
       // this.data.projectName= '';
      let str = this.data.projectName;
      str = str.replace(/[^A-Z0-9]+/ig, "_");
      this.data.projectName=str;

    }
  }

1 Ответ

0 голосов
/ 16 января 2019

Получил код из stackoverflow при поиске ответа.

Я создал новый файл, вставил приведенный ниже код и добавил директивы в объявления app.moule.ts.

import { Directive, HostListener, ElementRef, Input } from '@angular/core';
@Directive({
selector: '[specialIsAlphaNumeric]'
})
export class SpecialCharacterDirective {

regexStr = '^[a-zA-Z0-9_]*$';
@Input() isAlphaNumeric: boolean;

constructor(private el: ElementRef) { }


@HostListener('keypress', ['$event']) onKeyPress(event) {
return new RegExp(this.regexStr).test(event.key);
}

@HostListener('paste', ['$event']) blockPaste(event: KeyboardEvent) {
this.validateFields(event);
}

validateFields(event) {
setTimeout(() => {

  this.el.nativeElement.value = this.el.nativeElement.value.replace(/[^A-Za-z ]/g, 
'').replace(/\s/g, '');
  event.preventDefault();

}, 100)
}

}

и затем в mat-input я использовал объявление specialIsAlphaNumeric

<mat-form-field color="accent">
                            <input
                                matInput specialIsAlphaNumeric
                                class="form-control"
                                placeholder="name"
                                [(ngModel)]="data.projectName"
                                name="name"
                                required
                                minlength="4"
                            />

                            <mat-error *ngIf="formControl.invalid">{{
                                getErrorMessage()
                            }}</mat-error>
                        </mat-form-field>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...