4

我正在使用 $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);
        }
      }
    })

工厂.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
    };
  }])

在第一页加载它工作,然后如果我浏览,而不刷新,验证/登录我得到一个控制台错误:

[$cacheFactory:iid] CacheId 'langCache' 已经被占用了!

似乎(因为我在每条路线上都调用工厂方法)它不能使用相同的 id !?

我实际上不知道该怎么做才能解决此问题,请提供任何帮助,谢谢。

4

2 回答 2

10

这对我有用:

cache = $cacheFactory.get('langCache') || $cacheFactory('langCache');
于 2017-02-11T00:32:27.960 回答
0

好的,感谢 IRC 上的一个人,我解决了这个问题,我只需要改变这个:

var getLangFile = function (langCode) {

      var deferred = $q.defer()
        , cache = $cacheFactory('langCache');

var cache = $cacheFactory('langCache')
  , getLangFile = function (langCode) {

      var deferred = $q.defer();
于 2014-09-05T08:51:39.823 回答