如何将promise的属性修改为等于AngularJS中对象的属性?

时间:2015-07-17 14:51:17

标签: javascript angularjs

基本上,我试图在一个服务中创建一个泛型函数,该函数获取一个对象的值,并检查是否与另一个对象一起查看是否共享了它的任何参数,如果它们是,则替换原始对象的参数值新对象中共享参数的值。此函数适用于任何JSON对象,如下所示:

load: function(loadTrue, settings1, settings2) {
  if (loadTrue) {
    for (var prop in settings1) {
      if (settings2.hasOwnProperty(prop)) {
        settings1[prop] = settings2[prop];
      }
    }
    return settings1;
  }
  else{
    return settings1;
  }
},

就像我说的,这适用于任何JSON对象,但我现在面临的问题是当我尝试将资源与对象进行比较时(此函数中的第二项始终必须是普通的JSON)对象由于我的项目的性质,但我不能总是返回一个对象,有时它是一个我要返回的资源。)

以下是我在控制台中记录时所比较的两个对象:

图1

Settings1: Resource {$promise: Object, $resolved: false}
Settings2: Object {class: "messageType", id: 181, message: "Test messageee"…}

然而,当扩展时,两者看起来非常相似:

图2

Settings1:
$promise: Object
$resolved: true
class: "messageType"
id: 181
message: "Test"
messageName: "testing 1"

Settings2:
class: "messageType"
id: 181
message: "Test messageee"
messageName: "testing 1"

如您所见,我基本上需要将settings1中的message属性覆盖为settings2的属性。问题似乎是(当通过调试器时),而不是通过图[2],angualr似乎透过图[1]看到两个对象之间没有共享参数,因此没有任何过度写

此方法调用如下:

$scope.subject = myService.load($scope.loadIsTrue, $scope.subject, $localStorage.subject2);

主题声明如下:

$scope.subject = messageService.messageResource.get({messageName: 'test'});

1 个答案:

答案 0 :(得分:1)

尝试以下更改:

在您的messageService服务中(您必须更改此内容以符合您的方法):

get: function (message) {
            var deferred = $q.defer();

            $http({
                url: '/YourHTTPcall',
                method: "GET",
                dataType: 'json'
            }).success(function (data, status, headers, config) {                    
                deferred.resolve(data);                                                        
            }).error(function (data, status, headers, config) {

            });
            //This line is key
            return deferred.promise;
        }

然后在您的其他代码中进行调用

messageService.messageResource.get({messageName: 'test'}).then(function(data){
   $scope.subject = data;
}).then(function() {
   myService.load($scope.loadIsTrue, $scope.subject, $localStorage.subject2);
});