angular - 如何仅允许数字指令角度 9 的复制粘贴
问题描述
我有一个只接受数字的文本框字段。当输入文本框而不是数字时,它不允许。
问题:1)复制+粘贴需要只允许数字吗?2)如果我阻止复制粘贴,它会阻止所有。
怎么做。目前,它允许所有人。
这是指令。
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
@Directive({
selector: '[OnlyNumber]'
})
export class NumericDirective {
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 ||
// Allow: Ctrl+A
// (e.keyCode == 65 && e.ctrlKey === true) ||
// Allow: Ctrl+C
// (e.keyCode == 67 && e.ctrlKey === true) ||
// // Allow: Ctrl+X
// (e.keyCode == 88 && e.ctrlKey === true) ||
// Allow: home, end, left, right
(e.keyCode >= 35 && e.keyCode <= 39)) {
// let it happen, don't do anything
return;
}
// Ensure that it is a number and stop the keypress
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
}
}
}
解决方案
经过一番研究,我发现了这种方法。我不确定这是否是最干净的工作,但它可以完成复制/粘贴方面的工作。
@HostListener('keyboard,['$event']
onKeyDown(event: KeyboardEvent) {
// Define Regex
// This will allow copy and select all to happen without any issues.
if (event.metaKey) {
if (event.key.toLowerCase() === 'a' || event.key.toLowerCase() === 'c' || event.key.toLowerCase() === 'v') {
return;
}
}
//Validate the keystrokes across regex
}
@HostListener('paste', ['$event'])
onPaste(event: ClipboardEvent) {
let dataToPaste = event.clipboardData.getData('text');
// Validate 'dataToPaste' against the regex
}
如上,除了监听keydown事件之外,我还为粘贴事件添加了监听器。我建议根据正则表达式验证文本的功能是一个单独的功能。验证要复制的文本将确保我们只有数字。
推荐阅读
- ios - 带有 Git-LFS 的 SPM 操作无法完成。(XCBUtil.BinaryReaderError 错误 2。)
- r - 有没有办法在 data.table 中滚动连接以匹配同时发生的多个观察?
- algorithm - 使用 FFT 查找所有可能的固定大小子集和
- docker - 如何让 EKS 与 CircleCI 一起工作?
- java - Java 未来
验证是成功还是失败? - adobe - AEM 样式类放置在 Paraformat 类中
- server - NestJS ServerMqtt 是客户端连接吗?不是服务器吗?
- javascript - SVG单向过渡
- sql-server - PowerShell New-AzSqlDatabaseImport - 0:无法访问存储帐户。请检查存储帐户名称和密钥,然后重试
- php - 在 PHP 8.0 上运行的 Laravel 5.8