假设您有以下文档:
{ title: 'take out the trash', priority: 'medium' }
你有两个不同的客户同时编辑这些数据,例如客户端1想要将标题更改为清理菜肴,客户端2想要将优先级更改为 high 。
如何使用pouchdb实现这一点?
答案 0 :(得分:2)
Update handlers和partial updates,但是每次更新都需要REST调用,这使得使用pouchdb脱机工作和稍后同步的目的失败了。另一种解决方案是使用每个文档都是delta 方法。
此函数检索所有文档:
function merge(obj1, obj2) {
for (var i in obj2) {
obj1[i] = obj2[i];
}
}
function all(db) {
return new Promise(function(fulfill, reject) {
var docs = {};
db.allDocs({include_docs: true}, function(err, doc) {
// sort by createdAt as cannot guarantee that order preserved by pouch/couch
doc.rows.sort(function(a, b) {
return a.doc.$createdAt > b.doc.$createdAt;
});
doc.rows.forEach(function(el, i) {
if (!el.doc.$id) { // first delta for doc?
el.doc.$id = el.doc._id;
}
if (docs[el.doc.$id]) { // exists?
merge(docs[el.doc.$id], el.doc);
} else {
docs[el.doc.$id] = el.doc;
}
if (i == doc.rows.length - 1) { // last element?
fulfill(docs);
}
});
});
});
}
此功能允许您进行部分更新:
function put(object, db) {
object.$createdAt = (new Date()).toJSON();
return new Promise(function(fulfill, reject) {
db.post(object).then(function(object) {
fulfill(object);
});
});
}
有关完整示例,请参阅Partial Updates Using Pouch