Angular指令 - 只允许输入数字和两位小数,以逗号分隔
创始人
2024-10-30 22:30:18
0

可以使用Angular的自定义指令来实现只允许输入数字和两位小数,以逗号分隔的功能。下面是一个示例代码:

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

@Directive({
  selector: '[appNumberFormat]'
})
export class NumberFormatDirective {

  constructor(private el: ElementRef) { }

  @HostListener('input', ['$event'])
  onInputChange(event: any) {
    const initialValue = this.el.nativeElement.value;
    let newValue = initialValue.replace(/[^0-9.,]/g, ''); // 只允许数字、逗号和句点
    newValue = this.formatNumber(newValue); // 格式化数字

    if (initialValue !== newValue) {
      this.el.nativeElement.value = newValue;
      event.stopPropagation();
    }
  }

  private formatNumber(value: string): string {
    const parts = value.split('.');
    const integerPart = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ','); // 每三位数字加一个逗号

    let decimalPart = '';
    if (parts.length > 1) {
      decimalPart = parts[1].substring(0, 2); // 只保留两位小数
    }

    return integerPart + (decimalPart ? '.' + decimalPart : '');
  }
}

在模板中使用该指令:


这样,输入框就只能输入数字、逗号和句点,并且会自动格式化为每三位数字加一个逗号的形式,保留两位小数。

相关内容

热门资讯

黑侠破解wepoker!hhp... 黑侠破解wepoker!hhpoker俱乐部是干嘛的(透视)app-都是普及真的是有挂1、上手简单,...
透视分享!wpk真吗(透视)德... 透视分享!wpk真吗(透视)德州局怎么透视,教程法门(有挂功能)-哔哩哔哩1、德州局怎么透视公共底牌...
cloudpoker透视!we... cloudpoker透视!wepokerplus开挂(透视)挂-总是透视是有挂1、许多玩家不知道we...
透视解谜!德普之星透视免费(透... 透视解谜!德普之星透视免费(透视)wepoker怎么拿到好牌,教程阶段(有挂方式)-哔哩哔哩wepo...
wepoker私人辅助器!we... wepoker私人辅助器!wepoker到底有没有透视(透视)插件-好像开挂存在有挂1、这是跨平台的...
透视必备!悦扑克脚本(透视)w... 透视必备!悦扑克脚本(透视)wepoker透视底牌脚本,教程项目(真实有挂)-哔哩哔哩1、透视必备!...
sohoo竞技联盟辅助器!we... sohoo竞技联盟辅助器!wepoker辅助是真的假的(透视)软件-其实解迷真的是有挂该软件可以轻松...
透视普及!wepoker智能辅... 透视普及!wepoker智能辅助插件(透视)购买wepoker模拟器,教程妙计(发现有挂)-哔哩哔哩...
wepoker有辅助插件吗!w... wepoker有辅助插件吗!wepoker透视辅助下载(透视)技巧-原来曝光真的有挂小薇(辅助器软件...
透视透视!hh poker透视... 透视透视!hh poker透视器下载(透视)hhpoker哪个俱乐部靠谱,教程绝活儿(真的有挂)-哔...