我使用pouchdb监视后端(couchdb)的更改,并将新添加的项推送到前端。这是同步代码,但是是否有任何限制返回文档的选项?
localDB.sync(remoteDB, {
live: true,
retry: true
})
没有限制选项的问题是我无法说出前10或20条记录。
答案 0 :(得分:0)
如果您的目标是同步,但仅针对特定数量的文档,请使用change
观察程序进行计数,并在达到极限时中止操作。
var count = 0,
limit = 10;
var sync = PouchDB.sync('mydb', 'http://localhost:5984/mydb', {
live: true,
retry: true
}).on('change', function (info) {
if (count++ >= limit) {
sync.cancel();
}
})
请注意,这将在10个更改之后取消同步,这与10个文档不同。可能是对同一文档进行10次更改。
如果您关心实际文档,则需要更复杂的逻辑来跟踪已更改文档的数量。
答案 1 :(得分:0)
说实话,我不确定同步是否适合您的用例。
仅同步部分数据将无法确保对现有文档的更新。
如果只想说10-20个最新的数据集,您可以做的是定期查询服务器上的视图,如果不需要脱机,则将结果本地保存在memory / localStorage / indexedDb中编辑它们。
如果要脱机编辑它们,可以将它们放入具有上游同步的PouchDB中。至 将它们插入数据库中,同时保留_rev,则可以将PouchDBs bulkDocs Api与选项{new_edits:false}
一起使用db.bulkDocs([
{
title : 'Lisa Says',
artist : 'Velvet Underground',
_id : "doc1",
_rev : "1-84abc2a942007bee7cf55007cba56198"
},
{
title : 'Space Oddity',
artist : 'David Bowie',
_id : "doc2",
_rev : "1-7b80fc50b6af7a905f368670429a757e"
}
],
{new_edits: false}).then(function (result) {
// handle result
}).catch(function (err) {
console.log(err);
});
来源: