0

我有以下文档结构:

{
  "_id": "car_1234",
  "_rev": "1-9464f5d70547c255a423ff8dae653db1",
  "Tags": [
    "Audi",
    "A4",
    "black"
  ],
  "Car Brand": "Audi",
  "Model": "A4",
  "Color": "black",
  "CarDealerID": "5"
}

Tags字段将文档的信息存储在列表中。这种结构需要保持这样。现在用户有机会在 HTML 文本输入字段中搜索汽车,其中 a,表示汽车之间的分隔。让我们看下面的例子:

黑色奥迪,粉色奥迪 A4

在这里,用户想要找到黑色奥迪或粉色奥迪 A4。我通过数据库查询的方法是将输入的单词拆分为以下结构,如果子数组中的所有单词(例如“black”和“Audi”)都存在,则在 db 中每个文档[["black", "Audi"],["pink", "Audi", "A4"]]的字段内进行搜索,并且返回.TagsCarDealerID

 ///Before this I return the word list as described
 }).then(function (wordList) {
 results = [];

 for (var i = 0; i < userWords.length; i++) {

    //Check if the object is a single word or an array of words
    if (wordList[i].constructor === Array) {

         //Recreate the words in the array as one string
         wordString = ""
         wordList[i].forEach(function (part) {
             wordString += part + " "
         })
         wordString = wordString.trim()

         //Search for the car
         car_db.search({
             query: wordString,
             fields: ["Tags"],
             include_docs: true
             }).then(function(result) {
                 result.rows.forEach(function (row) {
                    results.push(row.doc.CarDealerID)
                 })
             })

    } else {
       car_db.search({
           query: userWords[i],
           fields: ["Tags"],
           include_docs: true
           }).then(function(result) {
               result.rows.forEach(function (row) {
                  results.push(row.doc.CarDealerID)
               })
           })
    }

    return results

   }).then(function(results) {
         console.log(results)
   }).catch(function (err) {
         console.log(err)
   });

我的问题

我现在的问题是在for循环完成之前返回结果。这可能是因为它是一个异步过程,结果应该等待返回,直到这个异步完成。但我不知道如何实现这一目标。我希望有人可以帮助我。

4

1 回答 1

0

感谢Nolan Lawson 的博客 (Rookie Mistake #2),我可以弄明白。而不是for循环,我使用

return Promise.all(wordList.map(function (i) {
     results = [];
     //
     //Same Code as before
     //
     //Return results inside the map function
     return results;
}));
于 2016-11-03T20:21:40.210 回答