我有以下文档结构:
{
"_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"]]
的字段内进行搜索,并且返回.Tags
CarDealerID
///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
循环完成之前返回结果。这可能是因为它是一个异步过程,结果应该等待返回,直到这个异步完成。但我不知道如何实现这一目标。我希望有人可以帮助我。