คุณสามารถใช้คำสั่ง angular2 พลันคร
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
@Directive({
selector: '[OnlyNumber]'
})
export class OnlyNumber {
constructor(private el: ElementRef) { }
@Input() OnlyNumber: boolean;
@HostListener('keydown', ['$event']) onKeyDown(event) {
let e = <KeyboardEvent> event;
if (this.OnlyNumber) {
if ([46, 8, 9, 27, 13, 110, 190].indexOf(e.keyCode) !== -1 ||
(e.keyCode === 65 && (e.ctrlKey || e.metaKey)) ||
(e.keyCode === 67 && (e.ctrlKey || e.metaKey)) ||
(e.keyCode === 86 && (e.ctrlKey || e.metaKey)) ||
(e.keyCode === 88 && (e.ctrlKey || e.metaKey)) ||
(e.keyCode >= 35 && e.keyCode <= 39)) {
return;
}
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
}
}
}
และคุณต้องเขียนชื่อคำสั่งในข้อมูลที่คุณป้อนเป็นแอตทริบิวต์
<input OnlyNumber="true" />
อย่าลืมเขียนคำสั่งของคุณในอาร์เรย์การประกาศของโมดูลของคุณ
เมื่อใช้ regex คุณจะต้องใช้คีย์ที่ใช้งานได้
export class OnlyNumber {
regexStr = '^[0-9]*$';
constructor(private el: ElementRef) { }
@Input() OnlyNumber: boolean;
@HostListener('keydown', ['$event']) onKeyDown(event) {
let e = <KeyboardEvent> event;
if (this.OnlyNumber) {
if ([46, 8, 9, 27, 13, 110, 190].indexOf(e.keyCode) !== -1 ||
(e.keyCode == 65 && e.ctrlKey === true) ||
(e.keyCode == 67 && e.ctrlKey === true) ||
(e.keyCode == 86 && e.ctrlKey === true) ||
(e.keyCode == 88 && e.ctrlKey === true) ||
(e.keyCode >= 35 && e.keyCode <= 39)) {
return;
}
let ch = String.fromCharCode(e.keyCode);
let regEx = new RegExp(this.regexStr);
if(regEx.test(ch))
return;
else
e.preventDefault();
}
}
}