【发布时间】:2016-04-08 13:17:38
【问题描述】:
我正在使用 Backand 为我的 Angular 应用程序提供数据库和 REST api。
我正在开发一种功能,让用户可以对复杂对象进行编辑,然后应该在数据库中更新该对象。够直白了吧……
对象看起来有点像这样:
obj = {
id: 1, // assigned by the db
name: "My List",
tasks: [
{ id: 1, desc: "Task 1" },
{ id: 2, desc: "Task 2" },
...
]
}
对于更新 ($http PUT) 调用,我想使用 params: { deep: true } 作为最小化代码和 $http 调用的快捷方式。
目前的问题是,当 PUT 命令更新数据库中的“主”对象时,已编辑的“子”对象并未更新,而是作为新的子对象附加。
例如,如果我尝试在一次调用中更新主对象和子对象:
$http({
method: 'PUT',
url: baseUrl + 'lists/' + list.id,
params: {
deep: true
},
data: {
id: 1,
name: "My To Do List",
tasks: [
{ id: 1, desc: "New Description for Task 1" },
{ id: 2, desc: "New Description for Task 2" }
]
}
}).then( .... );
数据库不会更新子对象,它会附加它们。以下是生成的对象在数据库中的方式:
list = {
id: 1,
name: "My To Do List", // Updated correctly
tasks: [
{ id: 1, desc: "Task 1" },
{ id: 2, desc: "Task 2" },
{ id: 3, desc: "New Description for task 1" }, // Added not updated
{ id: 4, desc: "New Description for task 2" } // Added not updated
]
}
我已经确定子对象的ids 是正确的。
有没有什么方法可以简洁地做到这一点,或者我是否甘愿分多个阶段做到这一点? deep = true 甚至可以与 PUT 一起使用吗? Backand docs 不用提了。
【问题讨论】:
标签: angularjs angular-http backand