我正在尝试使用网站的结果加载本地PouchDB。在本地加载结果后,我不想再次下载它们了。
为了避免这种情况,我得到一个存在的文件列表,然后在获取之前测试我是否已经加载它。
function DownloadFile($fname){
$query = {
include_docs: false,
attachments: false,
startkey: ['run',$fname].join(','),
endkey: ['run',$fname,'\uffff'].join(',')
};
db.allDocs($query).then(function (result) {
if ( result.rows.length !== 0 ) return;
$url = './runDb/' + $fname + '/results.xml';
$.ajax({
url: $url,
type: "GET",
dataType: "xml",
contentType: "text/xml",
async: true,
success: function (results,status,xhr) {
app.ParseResults($fname,results)
}
});
}).catch(function (err) {
console.log(err);
});
}
我遇到的问题是,当DownloadFile
被调用100次并且allDocs
查询最终返回某些内容时,我不再知道返回的原始查询没有结果。
PouchDb中有没有办法确定用于生成给定结果集的查询参数?
编辑:虽然我非常喜欢接受的答案,但这似乎是一个愚蠢的问题。实验(在浏览器中)表示$query
和$fname
将包含发起allDocs
调用的特定呼叫的正确范围值。
换句话说,我真的不需要做任何事情,它只是有效。显然,这高度依赖于JS的实现,因此接受的答案更好,因为它明确了所需的内容。
答案 0 :(得分:1)
这与PouchDB无关,它是一种可用于各种类似案例的解决方案。
以下答案假设您有一个有效的Promise
对象。
function DownloadFile($fname){
$query = {
include_docs: false,
attachments: false,
startkey: ['run',$fname].join(','),
endkey: ['run',$fname,'\uffff'].join(',')
};
return Promise.all([
$query,
db.allDocs($query),
]).then(function (resp) {
// you'll have your query right here.
var $query = resp[0]
var result = resp[1]
if ( result.rows.length !== 0 ) return;
$url = './runDb/' + $fname + '/results.xml';
$.ajax({
url: $url,
type: "GET",
dataType: "xml",
contentType: "text/xml",
async: true,
success: function (results,status,xhr) {
app.ParseResults($fname,results)
}
});
}).catch(function (err) {
console.log(err);
});
}