我已经在这个问题上敲了好几天,似乎无法弄明白......
我的路线如下:
$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命中。
有谁知道为什么会这样?它是否与解决方案有关,或者它是否处于粘性状态?
答案 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调用。将其添加到每个调用并刷新缓存。此后应该打算工作。