Angulr6 自定义指令 限制输入正整数

第一式 创建自定义指令

ng g d directives/positive-integer --module=xxx xxx指你所需要申明指令的模块,一般用作根模块,如果用懒加载可以放在公共模块内

第二式 定义指令匹配正则表达式

private regex: RegExp = new RegExp(/^[1-9]\d*$/); ^[1-9]\d*$为限制正整数

第三式 设置监听按键时的特殊按键

private specialKeys: Array<string> = [ 'Backspace', 'Tab', 'End', 'Home' ];

第四式 构造器获取原生对象

constructor(private el: ElementRef) { }

第五式 监听,使用@HostListener和onKeyDown事件

@HostListener('keydown', ['$event'])
  onKeyDown(event: KeyboardEvent) {
    if (this.specialKeys.indexOf(event.key) !== -1) {
      return;
    }
    const current: string = this.el.nativeElement.value;
    const next: string = current.concat(event.key);
    if (next && !String(next).match(this.regex)) {
      event.preventDefault();
    }
  }

第六式 想用就用

<input type="number"
                 class="ant-input small-input"
                 name="activityValue"
                 required
                 min=1
                 max=100
                 appPositiveInteger
                 placeholder="请输入1~100之间的整数"
                 [(ngModel)]="virtualDiscount.activityValue"
          />

完整代码

import {Directive, ElementRef, HostListener} from '@angular/core';

@Directive({
  selector: '[appPositiveInteger]'
})
export class PositiveIntegerDirective {
  private regex: RegExp = new RegExp(/^[1-9]\d*$/);
  private specialKeys: Array<string> = [ 'Backspace', 'Tab', 'End', 'Home' ];
  constructor(private el: ElementRef) { }
  @HostListener('keydown', ['$event'])
  onKeyDown(event: KeyboardEvent) {
    if (this.specialKeys.indexOf(event.key) !== -1) {
      return;
    }
    const current: string = this.el.nativeElement.value;
    const next: string = current.concat(event.key);
    if (next && !String(next).match(this.regex)) {
      event.preventDefault();
    }
  }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值