如何在 Angular 中将货币符号显示在右侧

问题描述 投票:0回答:11

我必须像这样显示欧元:

583 €

但是使用这段代码:

{{ price | currency:'EUR':true }}

我明白了

€583
,Angular core 中有没有选项可以将符号向右移动?许多欧洲国家使用右侧的符号(法国、德国、西班牙、意大利)。

angular pipe currency euro
11个回答
50
投票

从 Angular2 RC6 版本开始,您可以直接在应用程序模块(提供程序)中设置默认区域设置:

import {NgModule, LOCALE_ID} from '@angular/core';

@NgModule({
  providers: [{
      provide: LOCALE_ID,
      useValue: 'de-DE' // 'de-DE' for Germany, 'fr-FR' for France ...
    },
  ]
})

之后,货币管道应选择区域设置并将符号移至右侧:

@Component({
  selector:"my-app",

  template:`
    <h2>Price:<h2>
     {{price|currency:'EUR':true}}
  `
})

23
投票

这正在工作(角度 6) 在 html 方面:

{{ amount | currency: 'EUR':'symbol':undefined:'fr-FR' }}

在打字稿方面:

const number = 123456.789;
console.log(new Intl.NumberFormat('fr-FR', { style: 'currency', currency: 'EUR' }).format(number));

123.456,79 €


13
投票

我正在寻找这个答案,当前版本的 Angular 可以定义本地化和默认货币代码的提供者。

像这样。

import { BrowserModule } from '@angular/platform-browser';
import { NgModule, LOCALE_ID, DEFAULT_CURRENCY_CODE } from '@angular/core';

import localePt from '@angular/common/locales/pt';
import { registerLocaleData } from '@angular/common';

// Register the localization
registerLocaleData(localePt, 'pt-BR');

@NgModule({
  declarations: [
    AppComponent,
    NotificationListComponent
  ],
  imports: [
    BrowserModule,
    FormsModule,
    ReactiveFormsModule,
    HttpClientModule,
  ],
  providers: [
    {
      provide: LOCALE_ID,
      useValue: 'pt-BR'
     },
     {
       provide: DEFAULT_CURRENCY_CODE,
       useValue: 'BRL'
     },
    DataService,
    NotificationsService,
    GeoLocationService,
  ],
  entryComponents: components,
})

完成后,使用非常简单:

<div class="col-12" *ngIf="isContentInsurance.value">
     <h5 class="pull-left">Gst</h5>
     <span class="pull-right">-{{offers.contentInsurance | currency}}</span>
</div>

无需创建任何自定义管道或不同的自定义操作。


8
投票

对于 Angular12,你应该将其导入到你的模块中

import { registerLocaleData } from '@angular/common';
import localeDe from '@angular/common/locales/de';
import localeDeExtra from '@angular/common/locales/extra/de';

registerLocaleData(localeDe, 'de-DE', localeDeExtra);

在您的提供商部分

{
      provide: LOCALE_ID,
      useValue: 'de-DE'
}

你可以这样使用

{{ price | currency:'EUR'}}

结果会是这样的

    139,00 €

3
投票

老实说,我找不到任何内置的方法来做到这一点。 因此创建了名为 split 的自定义管道。

工作演示:http://plnkr.co/edit/KX7hfaV2i7CX2VFobM8R?p=preview

import{Component,provide,Pipe,PipeTransform} from '@angular/core';

@Pipe({name:'split'})
export class ShiftPosition implements PipeTransform {
  transform(items: any[], value: string): string {
      return items.substr(1)+' ' +items.substr(0,1);
  }
}


@Component({
  selector:"my-app",

  template:`
    <h2>Dashboard<h2>
     {{price|currency:'EUR':true|split:price}}
  `
})

export class AppComponent{      
  price=10;
}

3
投票

提供 LOCALE_ID 不是一个解决方案,因为我的应用程序是英语的,但显示了法语区域设置的货币。因此,如果我将 LOCALE_ID 设置为

fr-FR
,我的所有日期都是法语,这是不可接受的。

所以我只需选择十进制管道,然后在末尾添加符号。

<div>
    {{ document.totalTaxAmount | number:'1.2-2' }} EUR
</div>

这里的问题是,如果没有定义数字,那么最终只会得到符号。为了解决这个问题,我创建了一个非空管道:

@Pipe({
    name: 'notEmpty'
})
export class NotEmptyPipe implements PipeTransform {
    transform(value: any, replaceWith: any = ""): any {
        if (!value) {
            return replaceWith;
        }
        return value;
    }
}

并像这样使用它:

<div>
    {{ document.totalTaxAmount | number:'1.2-2' | notEmpty: '0' }} EUR
</div>

1
投票

我只是不想在本地使用“fr”,所以:

import { PipeTransform} from '@angular/core';
import { Pipe } from '@angular/core';
import {CurrencyPipe} from '@angular/common';

    @Pipe({ name: 'myCurrency' })
    export class MyCurrencyPipe extends CurrencyPipe implements PipeTransform {
    
      transform(value: any, currencyCode?: string, display?: 'code' | 'symbol' | 'symbol-narrow' | string | boolean, digitsInfo?: string, locale?: string): string | null {
         let result = super.transform(value, currencyCode, display, digitsInfo, locale);
         if (result.charAt(0)==='₽' || result.charAt(0)==='$' ){
           result = result.substr(1)+' ' +result.substr(0,1);
         }else if(result.substr(0,3)==="TJS" || result.substr(0,3)==="RUB"){
           result = result.substr(3) +" "+result.substr(0,3)
         }
         if ( Number(value) >0 ){
           result = "+ "+ result
         }else{
           result = "- "+ result
         }
         return result;
      }

}

1
投票

我创建了自己的管道来执行此操作,这也是通用的,如果 order.currency 中的值不同,它会自动更改货币,这与硬编码的货币不同

货币.pipe.ts

import { CurrencyPipe, getCurrencySymbol } from "@angular/common";
import { Pipe, PipeTransform } from "@angular/core";

@Pipe({name:'OmsCurrency'})
export class OmsCurrency implements PipeTransform {
  constructor() { }
  transform(value: string, curr: string): string {
    try {
      if (curr === "" || curr === null) {
        return value
      }
      else {
        return value + ' ' + getCurrencySymbol(curr,"narrow");
      }
    } catch (error) {
      return value + ' ' + curr;
    }

  }
}

并在 html 文件中添加管道

<div class="col-1 h5 text-right">
    {{( item.unitPrice ? item.unitPrice : "0.00" ) |  OmsCurrency: order.currency }}
</div>

1
投票

要在 Angular 中显示货币,我们可以利用 Angular 称为货币的内置管道。它使用给定的区域设置和货币代码将数字格式化为货币。

app.module.ts

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

providers: [{provide: LOCALE_ID, useValue: 'en-US'}] //replace 'en-US' with your locale

html

{{ price | currency }}

1
投票

好吧,我自己解决了这个问题,如下所示

{{ product.price | currency: product.currency:"":".2-2" }} {{ orderInfo?.currency }}

顺便说一句,如果我以正常方式设置管道的值,输出将是

{{ product.price | currency: product.currency:"symbol":".2-2" }}

TRY 45,666.00

但是自定义管道输入后,输出将是

{{ product.price | currency: product.currency:"":".2-2" }} {{ orderInfo?.currency }}

45,666.00 TRY 

-2
投票

这样做:

{{price | currency:'EUR':true:'1.0-0'}}

不需要额外的管道,它使用默认的货币管道

© www.soinside.com 2019 - 2024. All rights reserved.