这是一个基于我之前的问题 here 的问题。
本质上,我使用了 $q.all() 方法来解析多个 http 调用。然后我过滤并合并两个数据源。
这一切都非常有效。但我希望我的两个提要之一每 5 分钟刷新一次。通常,我会通过将以下计时器附加到代码末尾来实现此目的
var timer = $scope.intervalFunction = function() {
$timeout(function() {
/* function to call $http.get again */
$scope.intervalFunction();
}, 300000)
};
timer();
$timeout.cancel(timer);
我的问题是,由于我没有将 http 调用定义为单独的函数,并且我还“合并”两个源,因此如何仅调用这些源之一,然后进行相应更新而不制作多个列表项副本(这是我在多次尝试中发生过的事情)。
谢谢!
JSFiddle here
最佳答案
“我希望我的两个提要之一每 5 分钟刷新一次”。我不确定您是否可以使用两个 $q.all
请求之一来实现这一目的。我只是建议您在 $q.all
包装器之外发出另一个请求,并在获得第一个 $q 的结果后启动
请求。$timeout
。所有
需要说的是,我对此解决方案并不确定,因为我没有测试它,但希望这会起作用:
$q.all(promises)
.then(function(response) {
metadata = response.metadataPromise.data;
metrics = response.metricsPromise.data;
joinMetadataAndMetrics();
requestEveryFiveMinutes();
})
.catch (error) (function (error) {
console.log(error);
});
function requestEveryFiveMinutes() {
$interval(function() {
// here you can make the needed http request
yourRequest()
.then(function() {
// handle the response as needed
})
.catch(function(err) {
console.log(err);
})
}, 300000);
}
并且不要忘记在 Controller 中注入(inject)$interval
关于javascript - 刷新/定时器功能仅适用于 2 个提要中的 1 个 -- $q.all() 合并,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44441702/