Angular Translate:LocalStorage插件和requirejs错误

mes*_*ssy 0 javascript angularjs angular-translate

我正在将Angular与require.js结合使用.除此之外,我使用angular-translate插件.现在我添加了插件angular-translate-storage-local,我收到了这个错误:Error: [$injector:unpr] Unknown provider: $translateCookieStorageProvider <- $translateCookieStorage <- $translateLocalStorage <- $translate

通常我会说我忘了添加依赖项,但我没有(我猜)!

我的requirejs.config:

requirejs.config({
    shim: {
        angular: {
            exports: 'angular'
        },
        ngTranslateLoader: ['ngTranslate'],
        ngTranslateLocalStorage: ['ngTranslate']
    },

    paths: {
        ngTranslate: '../../vendor/angular-translate/angular-translate',
        ngTranslateLoader: '../../vendor/angular-translate-loader-static-files/angular-translate-loader-static-files',
        ngTranslateLocalStorage: '../../vendor/angular-translate-storage-local/angular-translate-storage-local'
    }
});
Run Code Online (Sandbox Code Playgroud)

我的module:

define(function(require) {
    require('ngTranslate');
    require('ngTranslateLocalStorage');
    require('ngTranslateLoader');

    var angular = require('angular');

    var app = angular.module('app', [
        'pascalprecht.translate'
    ])
        .config([$translateProvider', function ($translateProvider) {
            $translateProvider
                .useStaticFilesLoader({
                    prefix: '/language/',
                    suffix: '.json'
                })
                .preferredLanguage('en-DK')
                .useSanitizeValueStrategy('escape')
                .useLocalStorage();
        }]);
});
Run Code Online (Sandbox Code Playgroud)

静态文件加载器插件运行良好.我的失败在哪里?

编辑:我在requirejs配置中添加了以下内容:

ngTranslateLocalStorage: ['ngTranslateCookieStorage', 'ngTranslate'],
ngTranslateCookieStorage: ['ngCookies', 'ngTranslate'],
ngCookies: ['angular'],
Run Code Online (Sandbox Code Playgroud)

现在我得到: Error: [$injector:unpr] Unknown provider: $cookieStoreProvider <- $cookieStore <- $translateCookieStorage <- $translateLocalStorage <- $translate

如果我理解requirejs shim是正确的require(ngTranslateLocalStorage),那么现在应该已经足够了,但后来我收到了pascalprecht.translate未知的消息.如果我需要所有deps,虽然它已经在垫片中完成,我得到上面的错误.还是有问题!?

Mic*_*zos 7

服务$translateLocalStorage取决于$translateCookieStorage,依赖$cookieStoreangular-cookies.

因此,你需要还包括angular-translate-storage-cookie,angular-cookies和添加ngCookies的模块依赖.

总结一下,你应该:

"angular-translate"
"angular-translate-loader-static-files"
"angular-cookies"
"angular-translate-storage-cookie"
"angular-translate-storage-local"
Run Code Online (Sandbox Code Playgroud)