我尝试使用Angular为对象设置新属性。我可以看到属性设置了正确的值,但是当我想用另一个函数保存它时,属性就消失了。
这是我到目前为止所做的:
$scope.confirmTask = function(taskId, taskString){
campaignTaskCompleted(taskId, $scope.campaign._id).then(function(task){
//Here completed == true
console.log("task", task);
$scope.saveSocialPortal();
})
}
function campaignTaskCompleted(taskId, campaignId){
return new Promise(function(resolve){
for(var c =0; c < $scope.user.socialPortal.campaigns.length; c++){
if($scope.user.socialPortal.campaigns[c]._id == campaignId){
for(var i=0; i < $scope.user.socialPortal.campaigns[c].tasks.length; i++){
if($scope.campaign.tasks[i]._id == taskId){
$scope.campaign.tasks[i].completed = true;
resolve($scope.campaign.tasks[i]);
}
}
}
}
})
}
$scope.saveSocialPortal = function(){
//here completed is completely gone
console.log("save", $scope.user.socialPortal.campaigns[0].tasks);
$api.put('user-social-portal', {socialPortal: $scope.user.socialPortal})
.then(function(response) {
})
.catch(function(reason) {
console.log(reason);
})
}
这是什么原因?我该怎么做才能解决这个问题?
我混淆了不同的变量($scope.campaign
和$scope.user.socialPortal.campaigns
),所以有些事情从本页开头就出错了。
我完全重写了代码以始终使用$scope.user.socialPortal
,这是有效的。
答案 0 :(得分:1)
也许我正在读错你的代码。但是,您似乎只在completed
上将true
新属性设置为$scope.campaign.tasks[i]
,而不是$scope.user.socialPortal.campaigns[0]
。也许他们应该指向同一个对象?目前尚不清楚他们是否这样做。
难道你不至少需要以某种方式将已完成的广告系列推送到$scope.user.socialPortal.campaigns
阵列吗?