2

我对我的承诺有一种奇怪的行为。请参阅以下插件:http: //plnkr.co/edit/uBuBS3Oi7mIPob2jtqkm

它基于 Marc Galgleish 的一篇非常好的文章 ( http://markdalgleish.com/2013/06/using-promises-in-angularjs-views/ )。

在我的控制器中,我有一个名为 messages 的简单 $scope 属性(从服务获取延迟对象):

angular.module('myModule', [])
.controller('HelloCtrl', function($scope, HelloWorld) {
  $scope.messages = HelloWorld.getMessages();

  $scope.click = function()
  {
    alert($scope.messages[0]);
  }
});

正如预期的那样,在实现承诺(每次解析)后,视图会获取实际值并显示它们。但是单击按钮并执行单击功能,我无法按预期使用 $scope.messages。承诺没有在那里解决,只是在视图中。

与(http://plnkr.co/edit/vX3dSFjzB6R7q4Oed7Gj

HelloWorld.getMessages().then( function(data){
  $scope.messages = data;
});

一切正常,但这不是我的解决方案。在我的实际应用程序中,它是一个服务,它返回一个复杂的已经同步的缓存对象(来自本地存储),或者如果需要与服务器同步则返回一个承诺。同步后返回更新的对象。

有任何想法吗?

提前谢谢克努特

4

1 回答 1

3

即使解决了这个承诺,它仍然是一个承诺。

尝试这个:

$scope.click = function()
{
  $scope.messages.then(function(msgArray) {
    alert(msgArray[0]);
  });
}
于 2013-07-18T22:41:51.327 回答