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 : '');
  }
}

在模板中使用该指令:


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

相关内容

热门资讯

透视窍门!安装不了wepoke... 透视窍门!安装不了wepoker,aapoker辅助怎么用(透视)竟然真的有挂(哔哩哔哩)1、完成a...
透视要领!wpk德州局怎么透视... 透视要领!wpk德州局怎么透视,wpk辅助购买(透视)竟然真的有脚本插件(哔哩哔哩)1、该软件可以轻...
透视课程!拱趴大菠萝万能挂,w... 透视课程!拱趴大菠萝万能挂,wepoker辅助软件价格(透视)本来存在有挂(哔哩哔哩)1、首先打开w...
透视模板!hhpoker辅助靠... 透视模板!hhpoker辅助靠谱吗,hhpkoer辅助器(透视)好像存在有透视教程(哔哩哔哩)1、用...
透视经验!wepokerplu... 透视经验!wepokerplus辅助,hhpoker是真的吗(透视)本来有挂(哔哩哔哩)hhpoke...
透视法子!wpk透视是真的吗,... 透视法子!wpk透视是真的吗,wpk软件是真的吗(透视)原来存在有脚本攻略(哔哩哔哩)1、这是跨平台...
透视经验!aapoker怎么设... 透视经验!aapoker怎么设置提高好牌几率,竞技联盟透视(透视)原来是真的挂(哔哩哔哩)1)aap...
透视模板!德普之星透视免费,德... 透视模板!德普之星透视免费,德扑之心免费透视(透视)其实有透视攻略(哔哩哔哩)德扑之心免费透视是不是...
透视手段!xpoker辅助怎么... 透视手段!xpoker辅助怎么用,来玩app 德州 辅助(透视)都是真的是有挂(哔哩哔哩)来玩app...
透视资料!wepoker私人局... 透视资料!wepoker私人局开挂视频,wepoker有机器人吗(透视)果然存在有脚本技巧(哔哩哔哩...