我正在使用 $cacheFactory 来存储应用程序的语言 JSON 文件,并且我在每个新路由中运行一个工厂方法,如下所示:
index.js
$routeProvider
.when('/',{
'templateUrl':'views/home/index.html',
'controller':'Home',
'resolve': {
'onEnter': function ($rootScope, langFactory) {
return langFactory.getLangFile($rootScope.lang.appLang);
}
}
})
.when('/auth/login',{
'templateUrl':'views/auth/login.html',
'controller':'AuthLogin',
'resolve': {
'onEnter': function ($rootScope, langFactory) {
return langFactory.getLangFile($rootScope.lang.appLang);
}
}
})
factory.js
.factory('langFactory', ['$rootScope', '$window', '$http', '$cacheFactory', '$q', function ($rootScope, $window, $http, $cacheFactory, $q) {
var getLangFile = function (langCode) {
var deferred = $q.defer()
, cache = $cacheFactory('langCache');
if (!!!cache.get('cache' + $rootScope.lang.appLang)) {
$http.get(langCode + '-langFile-to-be-REMOVED.json').success(function (response) {
cache.put('cache' + $rootScope.lang.appLang, response);
deferred.resolve();
}).error(function (err) {
$window.console.error('Unable to retrieve app language: ' + err);
deferred.reject(err);
});
} else {
deferred.resolve();
}
return deferred.promise;
};
return {
'getLangFile':getLangFile
};
}])
在第一页加载它工作 ,然后如果我浏览,没有刷新,到 auth/login 我得到一个控制台错误:
似乎(因为我在每条路线上都调用了工厂方法)它不能使用相同的 ID!?
我实际上不知道该怎么做来解决这个问题,任何帮助 appriciated,谢谢。
最佳答案
这对我有用:
cache = $cacheFactory.get('langCache') || $cacheFactory('langCache');
关于javascript - Angularjs cacheFactory : id is already taken,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25658786/