AngularJS - 动态更改过滤器上的货币符号?

时间:2016-06-12 21:41:58

标签: angularjs angularjs-filter

问题背景:

我有一个下拉列表,其中包含4个不同的国家/地区选项:英国(英国),美国(美国),FR(法国),GER(德国)。根据选择的下拉值,我需要在Controllers Scope对象上过滤价格以显示正确的货币符号,例如:

如果我在复选框中选择“FR”,我希望在过滤器上看到“€”符号:

enter image description here

如果我想选择'UK',我会期望看到附加'£'等等。

问题:

如上所述,我可以选择4个不同的国家/地区,因此我需要能够 动态地 更改货币过滤器。

我试图通过Scope上的模型属性来设置它,但到目前为止还没有工作。

守则:

目前我正在使用标准的AngularJS Currency过滤器,如下所示:

       {{maxTextVal | currency : "€" : 2}}

maxTextVal是控制器Scope对象上的值。在上面的代码中,我硬编码欧元代码(€)来生成符号,这是我需要动态设置的过滤器值。

是否可以在运行时更改此值?任何帮助将不胜感激。

2 个答案:

答案 0 :(得分:2)

可以在运行时更改此设置,但我不确定货币过滤器是否有选项。

无论如何,您可以编写使用$sce.trustAsHtml(value)的自定义过滤器来正确显示符号。或者您也可以使用currencyFilter将过滤器注入您的范围并调用该函数并在那里使用$sce

请查看下面的演示或fiddle

angular.module('demoApp', [])
	.filter('currencyWithLocale', function(currencyFilter, $sce) {
    	return function(input, locale) {
        	locale = locale || {currency: '$'};
        	return $sce.trustAsHtml(currencyFilter(input, locale.currency));
        }
    })
	.controller('mainCtrl', MainCtrl);
    
function MainCtrl($sce) {
	var vm = this;
    angular.extend(vm, {
    	total: 10.1,
        locales: [{
        	id:0,
            short: 'GER',
            currency: '€'
        }, {
        	id:1,
            short: 'FR',
            currency: '€'
        },{
        	id:2,
            short: 'UK',
            currency: '£'
        }]
    });
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="demoApp" ng-controller="mainCtrl as ctrl">
    <select ng-model="ctrl.selectedLocale" ng-options="locale as locale.short for locale in ctrl.locales">
    </select>
    <span ng-bind-html="ctrl.total | currencyWithLocale: ctrl.selectedLocale"></span> 
    <!--<br/>
    below is not working because it's not $sanitized.<br/>
    {{ctrl.total | currency: ctrl.selectedLocale.currency}}-->

</div>

答案 1 :(得分:1)

不是传递文字&#34;€&#34;而是传递包含当前所选货币的范围变量:

{{maxTextVal | currency : selectedCurrency : 2}}

或者,假设您有一个选定的国家/地区,并且该国家/地区包含货币:

{{maxTextVal | currency : selectedCountry.currency : 2}}