У моїй програмі є служба 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і чекав, коли обіцянка буде вирішена. Але враховуючи, що мета функції полягає лише у тому, щоб завантажувати локал, користувачеві було б цілком чудово викликати його декілька разів.
Наразі я просто зберігаю єдину обіцянку і вирішую її, якщо користувач знову зателефонує до функції після успішного вибору локалу з сервера.
З того, що я можу сказати, це працює за призначенням, але мені цікаво, чи це правильний підхід.