4

这里的核心问题是我无法将 $cookies 注入到配置块中,并且在Angular Translate中配置静态文件加载似乎只能在配置块中完成。我有一个包含我的应用程序版本的 cookie,我想将它用作我的静态翻译文件的查询参数,以便在版本之间有一种缓存破坏形式。

这是代码:

(function( ) {
    'use strict';

    angular.module( 'vcp.core' ).
        config( configureTranslationResources );

    function configureTranslationResources( $translateProvider ) {

        var $cookies;
        angular.injector(['ngCookies']).invoke(['$cookies', function(_$cookies_) {
            $cookies = _$cookies_;
        }]);

        var vcpVersion = $cookies ? $cookies.get('vcp-version') : '';

        $translateProvider.useStaticFilesLoader({
            prefix: '/v2/assets/i18n/',
            suffix: '.json?v=' + vcpVersion
        });

    }

})( );

这感觉很奇怪,应该有更好的方法。我无法从 Angular Translate 文档中直观地了解如何在运行块中配置静态文件加载(并不是感觉比这种方法好得多),而且似乎没有办法在配置中获取 cookie通过 $cookiesProvider 阻止。

也许这种方法完全是一个坏主意,并且有更好的方法来解决问题?

4

1 回答 1

2

如果您的页面是动态生成的,您可以将版本号放在 HTML 中而不是 cookie 中。例如,在index.html单页应用程序中:

<script>
'use strict';
angular.module('vcp.settings', [])
.constant('vcpVersion', '{{vcp_version}}');
</script>

在哪里vcp_version注入服务器端。由于在部署期间它是静态的,因此您的服务器可以缓存生成的 HTML。

常量在配置期间可用,因此您可以将版本号注入到配置函数中,如下所示:

angular.module( 'vcp.core', ['vcp.settings'] ).
    config( configureTranslationResources );

function configureTranslationResources( $translateProvider, vcpVersion ) {
    ...
于 2016-05-02T14:41:35.220 回答