Angular2货币管道更改小数分隔符

时间:2016-04-26 07:52:40

标签: format angular currency

你好角色朋友,

我正在开发一个angular2应用程序(实际上是多个)。我住在荷兰。

目前,我正在使用以下内容格式化我的货币:

{{someIntegerWithCentsToBeDivided / 100 |货币: 'EUR':真: '1.0-2'}}

这显示500为Eurosign 5和501为Eurosign 5.01。

现在我们的dutchies真的像逗号一样,所以有人知道如何改变。到了,?

如果有人知道如何显示5,则奖励分数 - - 可选地,当没有分数时。 我现在的想法是扩展CurrencyPipe

4 个答案:

答案 0 :(得分:18)

你的问题可能已经解决了一段时间,但仅供其他荷兰开发人员(如我自己)参考:

创建自定义管道:

import {Pipe} from '@angular/core';

@Pipe({
    name: 'currencyFormat'
})
export class CurrencyFormat {
    transform(value: number,
        currencySign: string = '€ ',
        decimalLength: number = 2, 
        chunkDelimiter: string = '.', 
        decimalDelimiter:string = ',',
        chunkLength: number = 3): string {

        value /= 100;

        let result = '\\d(?=(\\d{' + chunkLength + '})+' + (decimalLength > 0 ? '\\D' : '$') + ')';
        let num = value.toFixed(Math.max(0, ~~decimalLength));

        return currencySign+(decimalDelimiter ? num.replace('.', decimalDelimiter) : num).replace(new RegExp(result, 'g'), '$&' + chunkDelimiter);
    }
}

现在你可以使用:

{{someIntegerWithCentsToBeDivided | currencyFormat}}

Pipe已包含所有荷兰语默认值,但您可以轻松更改它们或将它们用作模板中的参数。例如:

{{1234567 | currencyFormat:'$',2,' ','.',3}}

$12 345.67作为输出。

答案 1 :(得分:2)

我来不及但我找到了解决办法。

我只是创建一个管道来替换任何东西:

import { PipeTransform, Injectable, Pipe }     from '@angular/core';
@Pipe({
  name: 'replace'
})
@Injectable()
export class ReplacePipe implements PipeTransform {
  constructor(){}
  transform(item: any, replace, replacement): any {
    if(item == null) return "";
    item = item.replace(replace, replacement);
    return item;
  }
}

我用了两次来解决你的问题。

{{ 5.01999 | currency:'BRL':true | replace:'.':',' | replace:',00':',-' }}}

答案 2 :(得分:0)

您需要导入

import { registerLocaleData } from '@angular/common';
import localeIt from '@angular/common/locales/it'
registerLocaleData(localeIt, 'it');

并在视图中添加该管道

{{ 1000 | currency: 'EUR':'symbol':'.2-2':'it' }}

答案 3 :(得分:-1)

我发现所有这些解决方案都太大了,代码行太多,以致于无法实现如此小的目标。关于它们的好处是,如果您通过应用程序经常使用它们。对于较小的情况,我个人将使用这种方法:

<div>{{(checkout.delivery_fee | currency).replace('.',',')}}</div>

所以我可以显示类似以下内容:运费:$ 5,50

但是,如果需要显示大于1.000的值,则可以使用:

<div>{{(checkout.delivery_fee | currency).replace(',','x').replace('.',',').replace('x','.')}}</div>