我正在开发一个Angular应用程序(在CoffeeScript中)并且有一个小的PHP后端(是的,我知道),它为缓存版本(来自文件)或数据库中的一个提供承诺。
我为此写了一个工厂:
@myApp.factory 'apiModel', ($http, $q) ->
deferred = $q.defer()
apiData = null
getData = (fromDb) ->
fromDb = (fromDb == true)
url = 'api.php?do=get';
# Append &refresh to get from database
if fromDb then url += '&refresh';
$http.get(url).success (data) ->
apiData = data
deferred.resolve data
.error ->
deferred.reject e.what()
return {
get: (fromDb) ->
if apiData == null || fromDb == true then getData(fromDb)
else deferred.resolve(apiData)
return deferred.promise
}
我可以像以下一样简单地获取数据:
apiPromise = apiModel.get()
apiPromise.then (data) ->
$scope.updateData(data)
, (reason) ->
console.log reason
到目前为止,工作正常。
然后我想像这样刷新数据:
$scope.refreshData = ->
promise = apiModel.get(true) # get from DB
promise.then (data) ->
$scope.updateData(data)
, (reason) ->
console.log reason
哪个不起作用。当我在getData()
中记录响应时,它会显示正确的刷新数据,但是当我记录来自承诺的数据时(在$scope.refreshData()
中),它会显示旧数据。
我认为这是异步请求的问题(它会在promise.then
的数据之前将数据记录在getData()
,但这是承诺的目的,不是吗?
提前致谢
答案 0 :(得分:0)
问题来了,因为你保持全球化 对象只会被解决一次,所以为了避免这种情况你应该这样做 在get函数中声明延迟而不是在全局级