覆盖现有对象属性

问题描述

我在处理两小块代码时遇到问题,无法理解为什么其中一个有效而一个无效。

我有一系列“任务”。 当用户更新任务时,我需要更新 AuditLog,以显示更新。 我有两个代码块,第一个有效,第二个无效。

第一块 - 当我查看更新的任务时,它会显示更新的日志。

第二块 - 当我查看更新的任务时,日志没有更新。

我怀疑这与我引用和分配事物的方式有关。

这个块正确更新了“任务”,查看它会显示更新的“审计日志”。

//update task with server response 'a'
this.updateTask(task).subscribe(a => {
  let updatedTask = initializeTask(a);
  task.auditLog = updatedTask.auditLog;
});

然后我想我可以稍微简化一下代码... 但是当使用这个块时,当我查看任务时,它不显示更新的日志。 (我应该提到打印 'intializeTask(a)' 工作正常并打印更新的日志值,因此与此无关。

//update task with server response 'a'
this.updateTask(task).subscribe(a => {
  task = initializeTask(a);
});

我觉得我可能在 JavaScript 引用/分配变量等方面遗漏了一些基本的东西。也许有人可以解释一下。

提前致谢!

PS:initializeTask 只是确保没有任何未定义的内容并且日期格式正确:

export function initializeTask(t): Task {
    t.subject = t.subject || '';
    t.startTime = initDate(t.startTime);
    t.state = t.state || 'Published';
    t.createdBy = t.createdBy || '';
    if (t.auditLog) {
        t.auditLog.forEach(d => {
            d.createdOn = initDate(d.createdOn);
        });
    }
    return t;
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)