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

在模板中使用该指令:


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

相关内容

热门资讯

黑科技数据(aapoker辅助... 黑科技数据(aapoker辅助工具)外挂透明挂辅助设备(透视)总是是有挂(存在有挂)-哔哩哔哩1)a...
黑科技好友房(wepoke玄学... 黑科技好友房(wepoke玄学)外挂透明挂辅助设备(透视)一贯存在有挂(了解有挂)-哔哩哔哩1、进入...
黑科技好友房(aapoker有... 黑科技好友房(aapoker有外挂)外挂透明挂辅助代打(软件透明挂)总是是真的有挂(有挂详情)-哔哩...
黑科技了解(Wepoke实锤)... 黑科技了解(Wepoke实锤)外挂透明挂辅助器(ai代打)原来真的有挂(有挂解惑)-哔哩哔哩;1、W...
黑科技能赢(扑克之城)外挂透明... 黑科技能赢(扑克之城)外挂透明挂辅助神器(软件透明挂)果然真的是有挂(有挂实锤)-哔哩哔哩;1、该软...
黑科技挂(wpk大厅)外挂透明... 黑科技挂(wpk大厅)外挂透明挂辅助下载(智能ai)竟然是真的有挂(有挂秘籍)-哔哩哔哩1、让任何用...
黑科技有挂(聚星扑克)外挂透明... 黑科技有挂(聚星扑克)外挂透明挂辅助设备(智能ai)一贯是真的有挂(了解有挂)-哔哩哔哩;1)聚星扑...
黑科技app(wpk微扑克智能... 黑科技app(wpk微扑克智能)外挂透明挂辅助ai代打(透视)总是真的是有挂(有挂实锤)-哔哩哔哩;...
黑科技app(WPK代码)外挂... 黑科技app(WPK代码)外挂透明挂辅助ai代打(软件透明挂)原来是真的有挂(证实有挂)-哔哩哔哩1...
黑科技线上(Wepoke科技)... 黑科技线上(Wepoke科技)外挂透明挂辅助助手(软件透明挂)竟然存在有挂(真的有挂)-哔哩哔哩1、...