我正在使用angularjs 1.4.4
我试图更新$ locale动态并且它正在更新。当过滤器运行时,它使用正确的更新$ locale来评估自己。不幸的是旧的过滤器不会重新运行。
var englishMonths = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
var frenchMonths = ["janvier", "f\u00e9vrier", "mars", "avril", "mai", "juin", "juillet", "ao\u00fbt", "septembre", "octobre", "novembre", "d\u00e9cembre"];
$scope.array = [];
$scope.currentDate = 'english';
$scope.addDate = function(){
$scope.array.push(new Date());
};
$scope.switchDate = function(){
var monthArray = englishMonths
if($scope.currentDate === 'english'){
monthArray = frenchMonths;
$scope.currentDate = 'french';
}
else{
$scope.currentDate = 'english';
}
$locale.DATETIME_FORMATS.MONTH.length = 0;
for(var x = 0; x < monthArray.length; x++){
$locale.DATETIME_FORMATS.MONTH.push(monthArray[x] + ($scope.currentDate === 'french' ? "FRENCH" : ''));
}
};
而且在DOM:
<button data-ng-click="addDate()">Add Date</button>
<button data-ng-click="switchDate()">Toggle Language, current: {{ currentDate }}</button>
<hr></hr>
<div data-ng-repeat="date in array">
{{ date | date:'longDate' }}
</div>
如果您添加日期到阵列将在当前的语言评价。如果您更改语言,旧的日期将不会重新评估。
您可以在我所做的小提琴看到这一点:http://jsfiddle.net/wf8ojqjg/
所以我需要一种方法为$语言环境进行更新,这实际上可以归结为迫使所有的过滤器重新计算。
怎么样的解决方案,像[这](http://jsfiddle.net/davidepastore/wf8ojqjg/1/)? –
我有数组遍布我的应用程序,所以这是行不通的。 –
它们是否共享相同的结构?您可能有兴趣使用[服务](https://docs.angularjs.org/guide/services)。 –