AngularJS Factory在第一次API调用之后,不会ping服务器并返回旧的粘性状态

时间:2017-02-16 06:56:53

标签: angularjs angular-ui-router angular-http angular-ui-router-extras

我已经在这个问题上敲了好几天,似乎无法弄明白......

我的路线如下:



$stateProvider.state({
            name: 'core.portfolio',
            url: '/portfolio',
            controller: 'portfolioController',
            controllerAs: 'vm',
            templateUrl: 'app/portfolio/partials/base.html',
            deepStateRedirect: true,
            sticky: true,
            resolve: {
                portfolioPrepService: function (portfolioService) {
                    return portfolioService.getPortfolio();

                },

            }
        }).state({
                name: 'core.portfolio.company',
                url: '/1/:companyId',
                resolve: {
                    companyPrepService: companyPrepService
                },
                views: {
                    'company': {
                        controller: 'CompanyController',
                        controllerAs: 'vm',
                        templateUrl: 'app/portfolio/company/company.tmpl.html'

                    }
                },
            sticky: true,
            deepStateRedirect: true

            }
        );




和我的服务一样:



function companyService($http, API_CONFIG) {

        var service = {};
        service = {
            getCompany: getCompany
        };
        function getCompany(id) {
            return $http({
                method: 'GET',
                url: API_CONFIG.url + 'companies/' + id + '/?embedded={"round":1}',
                cache: false
            })
        }
        return service;


    }




当我在CompanyController中进行API调用时, companyService.getCompany(companyId) 该服务返回一个陈旧的对象,当我查看我的服务器日志时,我没有看到任何REST调用。

当我刷新页面时,再次进行api调用(根据PrepService),但是当在CompanyController上触发时,它会返回陈旧数据,而服务器上没有REST命中。

有谁知道为什么会这样?它是否与解决方案有关,或者它是否处于粘性状态?

2 个答案:

答案 0 :(得分:0)

$http返回一个承诺,所以尝试这样做,

companyService.getCompany(companyId).then(function(res){
  console.log(res)
})

并检查开发者工具的网络标签是否有任何请求

答案 1 :(得分:0)

似乎根据这个问题,这里有一个如何解决问题的黑客:

$http disabling caching does not work #1586



var req = {
 method: 'GET',
 url: 'http://example.com',
 headers: {
    'Cache-Control' : 'no-cache'
 }
}




您必须使用这些标头调用每个API调用。将其添加到每个调用并刷新缓存。此后应该打算工作。