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

在模板中使用该指令:


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

相关内容

热门资讯

6分钟辅助!德州局HHpoke... 6分钟辅助!德州局HHpoker透视脚本,sohoo辅助,操作教程(有挂猫腻)德州局HHpoker透...
八分钟辅助!hh poker辅... 八分钟辅助!hh poker辅助器先试用,wepoker手机版辅助,窍要教程(真的有挂)运hh po...
9分钟辅助!hh poker辅... 9分钟辅助!hh poker辅助有用吗,哈糖大菠萝有没有挂,模块教程(有挂头条)1、下载好哈糖大菠萝...
三分钟辅助!cloudpoke... 三分钟辅助!cloudpoker怎么开挂,来玩app破解版,绝活教程(有挂辅助)1、点击下载安装,c...
第1分钟辅助!德州局HHpok... 您好,wepoker私人局俱乐部怎么进这款游戏可以开挂的,确实是有挂的,需要了解加去威信【48527...
第9分钟辅助!wpk是真的还是... 第9分钟辅助!wpk是真的还是假的,来玩app破解,窍门教程(有挂总结)1、金币登录送、破产送、升级...
2分钟辅助!hhpoker可以... 2分钟辅助!hhpoker可以开挂吗,拱趴大菠萝挂怎么安装,练习教程(有挂头条)1、起透看视 拱趴大...
两分钟辅助!fishpoker... 两分钟辅助!fishpoker透视底牌,wepoker透视最简单三个步骤,演示教程(竟然有挂)1、金...
第三分钟辅助!hhpoker作... 第三分钟辅助!hhpoker作弊码,wepoker怎么看底牌,手段教程(有挂教程)wepoker怎么...
第9分钟辅助!aapoker辅... 第9分钟辅助!aapoker辅助器是真的吗,aa poker辅助包,绝活儿教程(有挂助手)1.aap...