我在我的应用程序中有一个i18n服务,其中包含以下代码:
var i18nService = function() {
this.ensureLocaleIsLoaded = function() {
if( !this.existingPromise ) {
this.existingPromise = $q.defer();
var deferred = this.existingPromise;
var userLanguage = $( "body" ).data( "language" );
this.userLanguage = userLanguage;
console.log( "Loading locale '" + userLanguage + "' from server..." );
$http( { method:"get", url:"/i18n/" + userLanguage, cache:true } ).success( function( translations ) {
$rootScope.i18n = translations;
deferred.resolve( $rootScope.i18n );
} );
}
if( $rootScope.i18n ) {
this.existingPromise.resolve( $rootScope.i18n );
}
return this.existingPromise.promise;
};
这个想法是用户调用ensureLocaleIsLoaded
并等待承诺被解决。但是,考虑到该函数的目的仅是确保区域设置已加载,如果用户多次调用它,也完全可以。
我目前只存储一个承诺,如果用户在从服务器成功获取区域设置后再次调用该函数,则解决它。
据我所知,这样做是按预期工作的,但我想知道这是否是适当的方法。