pouchDB检索allDocs原始查询

时间:2016-07-15 22:34:22

标签: pouchdb

我正在尝试使用网站的结果加载本地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的实现,因此接受的答案更好,因为它明确了所需的内容。

1 个答案:

答案 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);
  });
}