基本上,我试图在一个服务中创建一个泛型函数,该函数获取一个对象的值,并检查是否与另一个对象一起查看是否共享了它的任何参数,如果它们是,则替换原始对象的参数值新对象中共享参数的值。此函数适用于任何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'});
答案 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);
});