分配后角度,对象属性丢失

时间:2017-08-23 08:35:50

标签: javascript angularjs object

我尝试使用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,这是有效的。

1 个答案:

答案 0 :(得分:1)

也许我正在读错你的代码。但是,您似乎只在completed上将true新属性设置为$scope.campaign.tasks[i],而不是$scope.user.socialPortal.campaigns[0]。也许他们应该指向同一个对象?目前尚不清楚他们是否这样做。

难道你不至少需要以某种方式将已完成的广告系列推送到$scope.user.socialPortal.campaigns阵列吗?